我上传了我的~/.ssh/id_rsa。但是Git仍然会在每次操作(比如Git pull)时询问我的密码。我错过什么了吗?

它是一个私有存储库(另一个人的私有存储库的分支),我像这样克隆它:

git clone git@bitbucket.org:Nicolas_Raoul/therepo.git

这是我本地的。git/config:

[core]
        repositoryformatversion = 0
        filemode = true
        bare = false
        logallrefupdates = true
[remote "origin"]
        fetch = +refs/heads/*:refs/remotes/origin/*
        url = https://Nicolas_Raoul@bitbucket.org/Nicolas_Raoul/therepo.git
[branch "master"]
        remote = origin
        merge = refs/heads/master

在相同的环境下,使用相同的公钥,Github上的Git可以正常工作。 . ssh rwx -, . ssh / id_rsa - r -------, . ssh / id_rsa。Pub是-rw-r——r——


您确定您使用ssh url克隆了它吗?

url的来源说url = https://Nicolas_Raoul@bitbucket.org/Nicolas_Raoul/therepo.git,所以如果它是使用https,它会要求密码,不管你的ssh密钥。

所以你要做的是:

在当前的repo中打开配置文件。

一个git / problem。

并更改包含url的行

[remote "origin"]
        fetch = +refs/heads/*:refs/remotes/origin/*
        url = https://Nicolas_Raoul@bitbucket.org/Nicolas_Raoul/therepo.git

to

[remote "origin"]
        fetch = +refs/heads/*:refs/remotes/origin/*
        url = git@bitbucket.org:Nicolas_Raoul/therepo.git

在HTTP请求的情况下,也可以直接将凭据(带密码)粘贴到url中:

http://username:password@bitbucket.org/...

这样就省去了每次都要提交你的证书的麻烦。简单地修改你的.git/config (url)。


正如这里所解释的,如果您使用SSH url克隆,您不需要在每次推/拉时输入用户名/密码。检查上面@manojlds的回答

但是如果你想要使用HTTPS进行克隆,并且希望避免每次都输入用户名/密码,你可以使用以下命令将凭据存储到缓存中:

Git配置——全局凭据。Helper '缓存超时3600'

其中3600(秒)表示1小时,您可以根据自己的需求更改。


步骤1:安装git-credential-winstore https://confluence.atlassian.com/bitbucketserver/permanently-authenticating-with-git-repositories-776639846.html 步骤2:git配置——global credential。Helper '缓存超时3600' 这将存储您的密码1小时 步骤3:执行git命令 这将提示您输入密码,并提示凭据 并保存密码


上面已经回答了。我将总结上述检查步骤。

在项目目录下运行git remote -v。如果输出显示以https://abc开头的远程url,那么您可能每次都需要用户名和密码。

因此,要更改远程url,请运行git remote set-url origin {ssh远程url地址以git@bitbucket.org:}开头。

现在运行git remote -v来验证修改后的远程url。

参考:https://help.github.com/articles/changing-a-remote-s-url/


下面假设通过iTerm / Terminal命令行访问bitbucket。

对于MacOS Sierra 10.12.5,我的系统出现了一个同样的问题——在每个连接到bitbucket时都要求我的SSH密码。

此问题与macOS 10.12.2中的OpenSSH更新有关,此处的技术说明TN2449中对此进行了描述。

您很可能想要定制您的解决方案,但是当添加到您的~/时,以下内容将会起作用。ssh /配置文件:

Host *
    UseKeychain yes

有关ssh配置的更多信息,请查看ssh_config的手册页:

% man ssh_config

还有一件事:这里有一篇关于超级用户的很好的文章,讨论了这个问题,并根据您的需求和设置提供了各种解决方案。


您可能需要仔细检查您的SSH身份文件。你可能会引导BitBucket查看你在BitBucket中保存的等效公钥的不同/不正确的私钥。

用尾巴检查~/。Ssh /config -你会看到类似的东西:

Host bitbucket.org
 HostName bitbucket.org
 IdentityFile ~/.ssh/personal-bitbucket-ssh-key

请记住,添加额外的身份(如工作和家庭)可以通过ssh-add命令完成,例如:

ssh-keygen -t rsa -C "companyName" -f "companyName"
ssh-add ~/.ssh/companyName

一旦你确认了哪个私钥在本地被查看,你就可以获取你的公共等价密钥,在这种情况下:

cat ~/.ssh/personal-bitbucket-ssh-key.pub | pbcopy

然后把密码粘贴到BitBucket上。你的git推送现在将被允许(前提是你使用的是前面提到的答案所指出的SSH克隆)没有密码,因为你的设备是一个公认的友好。

希望这能帮你弄清楚。


你好,来自未来的谷歌人。

在MacOS >= High Sierra操作系统下,由于某些原因SSH密钥不再保存到KeyChain中。

使用ssh-add -K也不能在重启后存活。

这里有3种可能的解决方案。

我已经成功地使用了第一种方法。我在~/.ssh中创建了一个名为config的文件:

Host *
  AddKeysToAgent yes
  UseKeychain yes
  IdentityFile ~/.ssh/id_rsa

与我,虽然我运行'git克隆ssh://git@stash.xxx.com:7999/projName/projA.git' 我仍然被提示输入我克隆的这个新回购的密码,所以通过比较它的.git/配置文件与其他工作的回购,它原来是[远程“origin”]部分下的url,它被设置为ssh路径上面的新回购,但被设置为https:xxx的工作。


我登录的时候还有其他奇怪的地方。我遇到了一些看起来很蠢的东西,但对我来说很有用。只需进入MacOS的钥匙链。在侧边栏中找到登录锁图标。单击可退出,再单击可登录。听起来很蠢,但它解决了我的问题。值得一试。


这些答案都帮不了我,结果我的问题有点不同。ssh每次都在发送密钥之前询问我的密码。所以我要做的就是把我的密码和这个命令链接起来:

ssh-add -K ~/.ssh/id_rsa

然后它会提示您输入密码并存储密码。这可能是你正在寻找的解决方案,如果每次提示输入密码时,它会说

输入密钥'/Users//.ssh/id_rsa'的密码:

更多信息请点击这里

注意:我在我的mac机器上成功地使用了这个选项,但正如@Rob Kwasowski在下面指出的那样,大写K选项是mac独有的。如果不是在mac上,你将需要使用小写K(这可能也适用于mac,但我还没有测试)。


我用HTTPS URL克隆了存储库,而不是SSH URL,因此即使在添加SSH密钥后,它也在Bash Shell上询问我的密码。

我只是编辑了。/。并通过简单地将https://替换为ssh://来改变url变量的值

E.g.

[core]
        ...
        ...
        ...
[remote "origin"]
        url = https://<username>@bitbucket.org/<username>/<repository_name>.git
        fetch = +refs/heads/*:refs/remotes/origin/*
        ...
        ...
        ...

更改为:

[core]
        ...
        ...
        ...
[remote "origin"]
        url = ssh://<username>@bitbucket.org/<username>/<repository_name>.git
        fetch = +refs/heads/*:refs/remotes/origin/*
        ...
        ...
        ...

实际上,这些答案都没有反映Git的当前技术状态(在撰写本文时是v2.29)。在最新版本的Git中,cache、winstore、wincred已弃用。


如果你想通过HTTPS克隆一个Bitbucket存储库,例如。

Git 克隆 https://Kutlime@bitbucket.org/SomeOrganization/SomeRepo.git

你必须:

在Bitbucket用户管理中生成应用程序密码。 相应地在.gitconfig中设置凭据方法(全局或本地)

[credential]
    helper = manager

您可以通过执行此命令找到您的.gitconfig。

git config --list --show-origin

执行

git clone https://Kutlime@bitbucket.org/SomeOrganization/SomeRepo.git

并等待,直到登录窗口出现。使用url中的用户名(在我的例子中是kutlime)和您生成的应用程序密码作为密码。


我用我的用户名而不是电子邮件登录,它开始工作。


如果您使用的是Ubuntu系统,请使用以下方法永久存储密码:

git config --global credential.helper store

如果你仍然得到太多的身份验证失败错误:

nano ~/.ssh/config

粘贴:

Host bitbucket_james
    HostName bitbucket.org
    User james
    Port 22
    IdentitiesOnly=yes
    IdentityFile=~/.ssh/id_rsa_bitbucket_james

最重要的是-你应该bitbucket_james的别名而不是bitbucket.org当你设置你的远程URL:

git remote set-url origin git@bitbucket_james:repo_owner_user/repo_name.git

这里的关键字是'ssh://'而不是https://':-)

在你的。git/config中

请注意!如果你已经克隆了存储库,在你将你的公钥添加到BitBucket后,这些存储库可以重新克隆。这可能比侵入你的配置文件更干净;-)