将密码存储在 TortoiseHg 中
有没有办法配置 TortoiseHg 来存储我的密码?
我有一个托管在 Google 代码 上的项目,我使用 TortoiseHg 访问该项目。每当我想要将更改推送到 Google 代码时,TortoiseHg 都会提示我输入用户名和密码。 Google Code 要求我使用自动生成的密码,而且每次都要重复查找它。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(7)
现有的两个答案都建议将您的用户名和密码未加密存储在纯文本中,这是一个禁忌。
您应该使用 Keyring 扩展,因为它是专门为安全保存身份验证密码而设计的。它已经与 TortoiseHg 捆绑在一起,所以您所要做的就是通过在 mercurial.ini 文件中写入以下内容来激活它:
您还必须通过编辑存储库特定的 .hg\hgrc 将您的用户名与推送 URL 关联起来文件如下例所示:
有关将用户名与 url 关联的更多详细信息,请参阅 Keyring 扩展页面的 noreferrer">存储库配置 (SMTP) 部分。
Both existing answers suggest storing your username and password unencrypted in plain-text, which is a bit of a no-no.
You should use the Keyring extension instead, as it has been specifically designed for securely saving authentication passwords. It already comes bundled with TortoiseHg, so all you have to do is activate it by writing the following in your mercurial.ini file:
You will also have to associate your username with the push url by editing your repository-specific .hg\hgrc file like in the example below:
For more details on associating your username with the url, see the Repository Configuration (SMTP) section of the Keyring extension page.
三步,观看截图。
注意:这会以明文形式存储您的密码。
Three steps, watch screenshot.
Note: This stores your password in plaintext.
安全警告
尽管此答案已于 2017 年 9 月 15 日被接受,但它不是推荐的解决方案。您永远不应该以纯文本形式存储密码。请改用
mercurial_keyring
扩展。请参阅此处的另一个答案。您可以将推送 URL 更改为 https://username:[电子邮件受保护]/repo。
Google 代码 和 < a href="https://www.mercurial-scm.org/wiki/FAQ#FAQ.2BAC8-CommonProblems.How_can_I_store_my_HTTP_login_once_and_for_all_.3F" rel="noreferrer" title="Mercurial - 如何一次性存储我的 HTTP 登录信息所有?">Mercurial 的 常见问题解答。
编辑:Mercurial FAQ 解释了另一种方法:
Security warning
Although this answer is accepted as of 2017-09-15, it is not a recommended solution. You should never store your passwords in plain text. Use the
mercurial_keyring
extension instead. See another answer here.You can change your push URL to https://username:[email protected]/repo.
This is explained in Google Code's and Mercurial's FAQs.
EDIT: Mercurial FAQ explains another way to do it:
如果您想通过 TortoiseHg 配置它,可以使用“存储库设置”对话框。
打开对话框后,请切换到“同步”选项卡。
您可以添加包含 HTTPS 身份验证信息的路径。
http://tortoisehg.bitbucket.io/manual/2.9/ settings.html#module-web.settings
If you want to configure it via TortoiseHg, Repository Setting dialog is available.
After opening the dialog, please switch to 'Sync' tab.
You can add a path with HTTPS auth information.
http://tortoisehg.bitbucket.io/manual/2.9/settings.html#module-web.settings
只需修改本地存储库的
.hg
目录中的hgrc
文件,使其看起来像这样:其中 name 是您的 Google 代码登录信息,无需使用gmail/googlemail 位,例如“fredb”(不是[电子邮件受保护]), password 是 Google 生成的密码,yourproj 是您的 GC 项目的名称。所以像这样:
Simply modify the
hgrc
file in the.hg
directory of your local repository so it looks like this:where name is your Google Code login without the gmail/googlemail bit e.g. 'fredb' (not [email protected]), password is the Google-generated password, and yourproj is the name of your GC project. So something like:
这对我使用
SSH
有效。我知道密码是纯文本形式的,但这在这个项目中不是问题。您必须更改 myUser 和 MyOPas 的凭据以及 TortoisePlink.exe 的路径。
编辑 Mercurial.ini
This works for me using
SSH
. I know the password it's in text plain, but this is not a problem in this project.You have to change myUser and MyOPas for your credentials and the path to: TortoisePlink.exe.
Edit the mercurial.ini
如果您想将密码存储在 Mercurial.ini 中,并且在升级到 TortoiseHg 4.9 或更高版本后它不再起作用,可能的解决方案是将端口添加到前缀:
If you want to store the password in mercurial.ini and it doesn't work anymore after you upgrade to TortoiseHg 4.9 or higher a possible solution is to add the port to the prefix: