首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Net::HTTP::Unauthorized如何获取WWW-Authenticate标头?

Net::HTTP::Unauthorized如何获取WWW-Authenticate标头?
EN

Stack Overflow用户
提问于 2010-04-08 18:36:04
回答 1查看 2.4K关注 0票数 0

给定下面的代码...

代码语言:javascript
复制
Net::HTTP.start('localhost', 4000) do |http|
    #
    #   usual stuff omitted for clarity
    #
    @response = http.request(req)
end

..。如果一个(行为良好的)服务器返回一个401 (未授权的)响应,我如何获取WWW_Authenticate头?

我得到的最好的解决方案是一点也不好...

代码语言:javascript
复制
class Net::HTTPUnauthorized
    def get_header(h)
        _return = nil

        target = h.upcase

        self.header.each_header do |k, v|
            if k.upcase == target
                _return = v
                break
            end
        end

        _return
    end
end

克里斯

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2010-04-08 20:14:47

一种选择是使用halorgium's Rack-Client,它用机架端点包装Net::HTTP。然后,您可以像使用Rack应用程序一样与远程服务器进行交互:

代码语言:javascript
复制
response = Rack::Client.get("http://localhost:4000/foo/bar.baz")
response.code
# => 401
response.headers['WWW-Authenticate']
# => 'Basic realm="Control Panel"'
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2599126

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档