在git代理密码中退出@字符
我有git代理configuration为“http.proxy = http:// userId: pwd @ 123 @ipaddress:端口”,但克隆一个远程项目时,我得到错误
Cloning into git... error: Couldn't resolve proxy '123@ipaddress' while accessing http://git.kernel.org/pub/scm/git/git.git/info/refs fatal: HTTP request failed
如何逃避密码中的“@”字符?
请注意:我无法更改密码。
如果您在代理url中传递密码,我会尝试使用@符号的URL编码值:
http.proxy=http://userId:pwd%40123@ipaddress:port
附注(2013年11月)
对URL进行编码(特别是密码中的任何特殊字符)是正确的解决scheme。
下面提到的.netrc
只用于远程repo url,而不是用于parsing远程repo url的代理。
对于所述编码,请参阅“ 百分比编码 ”:
百分比编码(也称为URL 编码 )是在特定情况下对统一资源标识符 (URI)中的信息进行编码的机制。 虽然它被称为URL编码,但实际上,它主要在主要的统一资源标识符 (URI)集合中使用,其中包括统一资源定位符 (URL)和统一资源名称 (URN)。 因此,它也被用于准备application / x-www-form-urlencoded 媒体types的数据 ,正如在HTTP请求中提交HTML 表单数据时经常使用的那样。
百分比编码后的保留字符:
! # $ & ' ( ) * + , / : ; = ? @ [ ] %21 %23 %24 %26 %27 %28 %29 %2A %2B %2C %2F %3A %3B %3D %3F %40 %5B %5D
原文答复(2011年5月)
两点评论:
-
用http(不是https)访问服务器的密码是很奇怪的。 在客户端和服务器之间的通信过程中密码不encryption;
-
你可以在你的
$HOME
设置一个.netrc
(或者Windows的_netrc
),以下内容
机器IP地址:端口 loginuserId 密码pwd @
Git在场景背后使用的curl处理编码就好, @
或no @
。