Escape @ character in git proxy password
Asked Answered
L

5

109

I have git proxy config as 'http.proxy=http://userId:pwd@123@ipaddress:port' but while cloning a remote project, I'm getting error as

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

How to escape the '@' character in password?

Pls note: I cannot change the password.

Lyophilize answered 30/5, 2011 at 5:53 Comment(0)
O
203

I'd try using the URL Encoded value of the @ symbol (%40) if you're passing the password in the proxy url:

http.proxy=http://userId:pwd%40123@ipaddress:port
Overmatch answered 30/5, 2011 at 6:18 Comment(6)
I'm trying to do this same trick but with 'git clone user:pwd%40123@ip:port' and it doesn't work. So I guess git doesn't use curl in this situation?Digiovanni
interesting... not sure. It's probably worth trying to see what actually gets sent across the wire in this case.Overmatch
This helped me. You should separately url-encode both name and password parts. This will help you avoid any problems with special chars. For example there can be ":" sign which will also lead to problems.Futility
This is also awesome for when you have '@' in the username e.g. when you have email addresses as usernames.Emotionalize
Thank you so much for solving my problem after two days' struggle...really hard to find the reason for this kind of problem.Bacchant
Hello. Is there a list of URL Encoded values so i can save it and consult when i need it ?Burnout
Y
80

Note (November 2013)

Encoding the url (especially any special character in a password) is the right solution.
The .netrc mentioned below is only for remote repo url, not for the proxy used to resolve said remote repo url.

For said encoding, see "Percent-encoding":

Percent-encoding, also known as URL encoding, is a mechanism for encoding information in a Uniform Resource Identifier (URI) under certain circumstances. Although it is known as URL encoding it is, in fact, used more generally within the main Uniform Resource Identifier (URI) set, which includes both Uniform Resource Locator (URL) and Uniform Resource Name (URN). As such, it is also used in the preparation of data of the application/x-www-form-urlencoded media type, as is often used in the submission of HTML form data in HTTP requests.

Reserved characters after percent-encoding:

!   #   $    &   '   (   )   *   +   ,   /   :   ;   =   ?   @   [   ]
%21 %23 %24 %26 %27 %28 %29 %2A %2B %2C %2F %3A %3B %3D %3F %40 %5B %5D

Original answer (May 2011)

Two comments:

  • having a password for a server accessed with http (not https) is... strange. The password isn't encrypted during communications between client and server;

  • you could setup a .netrc (or _netrc for Windows) in your $HOME, with the following content

    machine ipaddress:port
    login userId
    password pwd@

The curl used by Git bbehind the scene would handle the encoding just fine, @ or no @.

Yoshi answered 30/5, 2011 at 6:10 Comment(2)
Thanks for ur answers. The server was network drive where only myself and other 2 developers will be using. So I think there is no need for encryption. And I will try using netrc sometime.Lyophilize
@Karthik: that will allow you to simply use: http://123@ipaddress:port/... as a cloning address, without having to add user and password information.Yoshi
H
13

You have to percent-encode | encode the special characters. E.g. instead of this:

http://user:Pa@[email protected]:80

you write this:

http://user:Pa%[email protected]:80

So @ gets replaced with %40.

Hemelytron answered 6/2, 2019 at 4:29 Comment(0)
C
12

URL encode any unusual characters.

List of url codes.

@ character is %40

In my git config file, I have encoded 'just' the user name for instance:

https://myemail%[email protected]/api.git
Chinch answered 14/11, 2018 at 10:39 Comment(0)
S
8

For example, your password stored in environment variable GIT_PASSWORD, username - GIT_USERNAME, then:

git clone http://${GIT_USERNAME}:$(echo -n $GIT_PASSWORD | hexdump -v -e '"x" 1/1 "%02X"' | tr x %)@repository.git

Explanation of: echo -n $GIT_PASSWORD | hexdump -v -e '"x" 1/1 "%02X"' | tr x %

  1. Print password: $GIT_PASSWORD <- hello
  2. Convert 'hello' to hex: hello <- x68x65x6Cx6Cx6F
  3. Change each 'x' to '%': x68x65x6Cx6Cx6F <- %68%65%6C%6C%6F
Shir answered 28/11, 2018 at 12:21 Comment(2)
In the first point of the explanation did you mean to use $GIT_PASSWORD instead of $GIT_REPOSITORY ?Cline
@NinjuBohra, thanks!Shir

© 2022 - 2024 — McMap. All rights reserved.