我在个人项目中使用了Mercurial,但每次想要推送到服务器时都需要输入用户名和密码。
我尝试将以下内容添加到我主目录下的.hgrc
文件中,但似乎完全被忽略了。
[ui]
username = MY_USER_NAME
password = MY_PASSWORD
如何以正确的方式实现这个功能?
你可以在你的.hgrc
或Mercurial.ini
文件中创建一个授权部分,如下所示:
[auth]
bb.prefix = https://bitbucket.org/repo/path
bb.username = foo
bb.password = foo_passwd
'bb'部分是一个任意标识符,用于将前缀与用户名和密码匹配 - 便于管理具有不同站点(前缀)的不同用户名/密码组合。
您也可以仅指定用户名,然后在推送时只需输入密码。
我还建议查看keyring扩展。因为它将密码存储在系统密钥环中而不是明文文件中,所以更安全。它在Windows上与TortoiseHg捆绑在一起,并且目前正在讨论在所有平台上分发它作为捆绑扩展的问题。
对我有效的格式(在我的~/.hgrc文件中)如下:
[ui]
username=Chris McCauley <chris.mccauley@mydomain.com>
[auth]
repo.prefix = https://server/repo_path
repo.username = username
repo.password = password
通过在唯一标识符前添加更多的前缀、用户名和密码三元组,您可以配置任意数量的存储库。
这仅适用于Mercurial 1.3,并且显然您的用户名和密码以明文形式存储,这样做并不好。
Mercurial完全支持SSH,因此我们可以利用SSH's ability to log into a server without a password - 您只需进行一次性配置即可提供自行生成的证书。 这是迄今为止最安全的方法,可以实现您想要的功能。
您可以在此处找到有关配置无密码登录的更多信息
如果您希望获得安全选项,但不熟悉SSH,请尝试这个。
来自文档...
该扩展程序会在第一次对给定远程存储库进行拉取/推送(就像默认情况下所做的那样)时提示HTTP密码,但会将密码(由用户名和远程存储库URL的组合键入)保存在密码数据库中。在下一次运行时,它会检查.hg/hgrc中的用户名,然后检查密码数据库中的合适密码,并在找到这些凭据时使用。
此处有更详细的信息
没有人提到密钥环扩展。它会将用户名和密码保存到系统密钥环中,这比上面提到的在静态文件中存储密码要安全得多。执行以下步骤,你就可以顺利完成了。我在Ubuntu上做到这一点只用了大约2分钟。
>> sudo apt-get install python-pip
>> sudo pip install keyring
>> sudo pip install mercurial_keyring
**Edit your .hgrc file to include the extension**
[extensions]
mercurial_keyring =
一个简单的技巧是在您项目的.hg/hgrc
文件中添加用户名和密码到推送URL:
[paths]
default = http://username:password@mydomain.com/myproject
(请注意这种方式会以明文存储密码)
如果您在同一域名下工作于多个项目,您可能希望在~/.hgrc
文件中添加重写规则,以避免为所有项目重复此操作:
[rewrite]
http.//mydomain.com = http://username:password@mydomain.com
由于密码以明文形式存储,因此我通常只存储我的用户名。
如果您在Gnome下工作,我将在这里解释如何集成Mercurial和Gnome Keyring:
http://aloiroberto.wordpress.com/2009/09/16/mercurial-gnome-keyring-integration/
没有人向新手用户解释或澄清术语,他们会被这些术语弄糊涂。
.hg/hgrc - 这个文件用于版本库,位于本地/工作区位置或实际版本库的.hg文件夹中。
~/.hgrc - 这个文件与上面的那个不同。该文件位于用户主目录(~)下。
myremote.xxxx=..... bb.xxxx=......
这是在使用mercurial钥匙扩展时,在[auth]部分/指令下的一行。确保你在那里放置服务器名称与你使用"hg clone"时匹配,否则钥匙才会说找不到用户。下面的bb或myremote是你在执行"hg clone http:/.../../repo1 bb或myremote"时必须给出的“别名名称”,否则它将无法工作或你必须确保你本地存储库的.hg/hgrc文件包含相同的别名,即(你在最后一个参数中给出的hg clone ..)。
PS:以下链接提供了详细信息,对于快速编写的语法错误,请谅解。
例如,如果在~/.hgrc(Linux/Unix中的用户主目录)或Windows上的mercurial.ini文件中包含以下行,如果你执行
`"hg clone http://.../.../reponame myremote"`
如果你在~/.hgrc文件下的[extensions]部分添加了"mercurial_keyring ="或者"hgext.mercurial_keyring = /path/to/your/mercurial_keyring.py"这样的一行,则每个http仓库链接只需要输入一次用户凭据。
[auth]
myremote.schemes = http https
myremote.prefix = thsusncdnvm99/hg
myremote.username = c123456
我正在尝试找出如何设置PREFIX属性,以便用户可以克隆或执行任何Hg操作,而无需输入用户名/密码提示,并且不用担心在使用Hg仓库链接时提到的http://..../...中的服务器名称是什么。它可以是IP、服务器名称或服务器的FQDN
使用MacPorts在Mac OSX上安装mercurial_keyring:
sudo port install py-keyring
sudo port install py-mercurial_keyring
# Add your username if you haven't already done so.
[ui]
username = email@address.com
[extensions]
mercurial_keyring =
虽然它可能适用于您的情况,但我发现使用Putty的Pageant生成公钥/私钥非常有用。
如果您也在使用bitbucket (.org),它应该可以让您向用户帐户提供公钥,然后到达存储库的命令将自动得到保护。
如果Pageant在重新启动时没有启动,您可以将Pageant的快捷方式添加到Windows“开始菜单”中,并且该快捷方式可能需要填写“属性”,以包含您的私有(.ppk)文件的位置。
有了这个设置,Mercurial和本地存储库将需要设置为使用SSH格式进行推送/拉取。
这里是Atlassian网站上关于Windows或Mac/Linux的详细说明。
您不必相信我的话,毫无疑问还有其他方法。也许这里描述的步骤更适合您:
- 从“开始”菜单中启动PuttyGen:开始 -> PuTTY-> PuttyGen
- 生成一个新的密钥,并将其保存为.ppk文件,不要设置密码
- 使用Putty登录到您想要连接的服务器
- 将PuttyGen中的公钥文本追加到~/.ssh/authorized_keys文件中
- 从“开始”菜单中创建一个快捷方式,指向.ppk文件:开始 -> Putty to Start -> Startup
- 在启动菜单中选择.ppk快捷方式(这将在每次启动时自动发生)
- 在系统托盘中看到Pageant图标了吗?右键单击它并选择“New session”
- 在“主机名”字段中输入username@hostname
- 现在您将自动登录。