当我克隆一个存储库时,我一直有点“忍受”Github总是问我的用户名和密码。我想绕过这一步,因为这是我的工作流中的一个烦恼。

我尝试使用本指南设置SSH密钥(我成功地做到了)。https://help.github.com/articles/generating-ssh-keys,我成功了。

我的问题是,当克隆一个存储库(使用SSH)时,我仍然被要求输入我的github密码和密码短语。我的理解是,在我设置了这个SSH密钥之后,我就不再需要这样做了。

我不知道该问什么,所以我就说说我的目标吧。

我希望能够克隆存储库,而不必一直把我的Github信息。

我的SSH密钥丢失了什么?如果有人能提供一些指导或资源,我会很感激,因为当涉及到GitHub中的SSH身份验证时,我总是感到有点失落。

据我所知,这是一个测试事情是否正常工作的命令,下面是来自我的控制台的输出:

~ $ ssh -T git@github.com
Saving password to keychain failed
Enter passphrase for key '/Users/MYNAME/.ssh/id_rsa':
Hi MYNAME! You've successfully authenticated, but GitHub does not provide shell access.

当我输入密码时,应该先失败吗?然后,当我输入密码时,它就通过了。


当前回答

正如在通过SSH从VSTS克隆Git回购中所解释的那样,要求密码!意想不到的

这个问题可能是因为公钥认证失败,所以它要求我的公司帐户的密码。

如果公钥身份验证成功,就不会发生这种情况。

你可以检查id_rsa。酒吧,甚至创建一个新的。

其他回答

如果你使用HTTPs url,它总是会询问你的用户名/密码。这个问题可以用@Manavalan Gajapathy的评论来解决(复制这里):

看这个github文档转换远程的URL从https到ssh。要检查remote的URL是ssh还是https,请使用git remote -v。从https切换到ssh:

git remote set-url origin git@github.com:USERNAME/REPOSITORY.git

如果您在克隆/设置远程时正确使用SSH:请确保您有一个SSH -agent来记住您的密码(参见@Komu的回答)。这样,每个终端会话只需要输入一次密码。

如果它仍然太烦人,那么简单地设置一个ssh-key没有密码短语。

一般来说,下面是允许您使用ssh远程连接到服务器的步骤,无需密码:

创建一对rsa私钥和公钥 $ ssh-keygen -t rsa -b 4096 -C "your comments" 复制您的公钥并登录到远程服务器 将您的公钥添加到.ssh/authorized_keys 如果您的计算机中有多个ssh密钥,您可能需要使用ssh-add添加密钥 $ ssh-add /path/to/private/key 然后尝试ssh到服务器 $ SSH username@your_ip_address

来源:http://diary-of-programmer.blogspot.com/2018/08/tips-how-to-ssh-to-your-digitalocean.html

尝试ssh-agent,请参见:https://help.github.com/articles/working-with-ssh-key-passphrases

添加没有钥匙串的身份

有时,您可能不希望密码短语存储在密钥链中,但又不想一次又一次地输入密码短语。

你可以这样做:

ssh-add ~/.ssh/id_rsa 

这将询问您的密码,输入它,它不会再问,直到您重新启动。

使用钥匙串添加身份

正如@dennis在评论中指出的那样,通过将密码保存在你的钥匙串中,你可以在添加这样的身份时使用——apple-use-keychain选项(Ubuntu的-k):

ssh-add --apple-use-keychain ~/.ssh/id_rsa

再一次,它将要求您输入密码,输入它,这一次它将不再要求您输入这个身份。

在Mac OSX上,您可以使用以下命令将您的私钥添加到keychain:

ssh-add -K /path/to/private_key

如果您的私钥存储在~/。SSH,命名为id_rsa:

ssh-add -K ~/.ssh/id_rsa

然后系统会提示您输入密码,该密码将存储在您的钥匙串中。

编辑-处理重启

为了在重新启动后也不必填写密码,在ssh配置文件中添加以下内容(通常位于~/.ssh/config)

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