Net :: http :: não autorizado - Como faço para chegar no cabeçalho www -autenticate?
-
25-09-2019 - |
Pergunta
Dado o código abaixo ...
Net::HTTP.start('localhost', 4000) do |http|
#
# usual stuff omitted for clarity
#
@response = http.request(req)
end
... Se um servidor (bem comportado) retornar uma resposta 401 (não autorizada), como faço para obter o cabeçalho www_authenticate?
A melhor solução que tenho não é nada de bom ...
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
Chris
Solução
Uma opção seria usar Cliência do rack de Halorgia, que envolve Net::HTTP
com um terminal de rack. Você interageria com o servidor remoto como se fosse um aplicativo de rack:
response = Rack::Client.get("http://localhost:4000/foo/bar.baz")
response.code
# => 401
response.headers['WWW-Authenticate']
# => 'Basic realm="Control Panel"'
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow