我正在使用登录名和密码进行https身份验证,根据RFC,URI应该如下所示:
https://username:password@example.com:8042/但是,当登录是电子邮件时,@符号被解释为主机分隔符:
https://username@example.com:password@example.com:8042/正确的URI应该是什么样的呢?
编辑一些背景:我正在检索PivotalTracker身份验证令牌
require 'net/http'
require 'net/https'
require 'open-uri'
def validate_with_credentials
doc = Nokogiri::XML(open(authentication_uri, :http_basic_authentication => [email, password]))
end
def authentication_uri
URI('https://www.pivotaltracker.com/services/v4/me')
end这很有效,但是我想在我的特性测试中对url进行存根,我使用的是FakeWeb gem:
FakeWeb.register_uri(:get, 'https://correct_email@example.com:correct_password@www.pivotaltracker.com/services/v4/me',
:body => File.read(File.join(Rails.root, 'spec', 'fixtures', 'pivotal_tracker', 'responses', 'authorization_success.xml')),
:status => ['200', 'OK'])这里的问题是uri不应该有双@,我得到了异常:
URI::InvalidURIError:方案https不接受注册表部分: correct_email@example.com:correct_password@www.pivotaltracker.com (还是坏主机名?)
发布于 2013-10-14 09:39:14
我必须使用编码并将@替换为%40。ravi parekh提供
https://stackoverflow.com/questions/19356532
复制相似问题