我上传了我的~/.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——


当前回答

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

其他回答

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

git config --global credential.helper store

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

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

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

步骤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/

实际上,这些答案都没有反映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)和您生成的应用程序密码作为密码。