Github权限被拒绝:ssh添加代理没有身份

这是我第一次访问GitHub,我没有使用控制台的经验。我在MacBook上使用Bash。当我尝试访问GitHub时,我得到了这个:

git clone git@github.com:dhulihan/league-of-legends-data-scraper.git
Cloning into 'league-of-legends-data-scraper'...
Permission denied (publickey).
fatal: Could not read from remote repository.


Please make sure you have the correct access rights
and the repository exists.

我试着按照Github页面上关于拒绝许可的说明进行操作。

当我使用ssh -vT git@github.com时,我得到以下结果:

OpenSSH_6.2p2, OSSLShim 0.9.8r 8 Dec 2011
debug1: Reading configuration data /etc/ssh_config
debug1: /etc/ssh_config line 20: Applying options for *
debug1: Connecting to github.com [192.30.252.129] port 22.
debug1: Connection established.
debug1: identity file /Users/XXXX/.ssh/id_rsa type -1
debug1: identity file /Users/XXXX/.ssh/id_rsa-cert type -1
debug1: identity file /Users/XXXX/.ssh/id_dsa type -1
debug1: identity file /Users/XXXX/.ssh/id_dsa-cert type -1
debug1: Enabling compatibility mode for protocol 2.0
debug1: Local version string SSH-2.0-OpenSSH_6.2
debug1: Remote protocol version 2.0, remote software version libssh-0.6.0
debug1: no match: libssh-0.6.0
debug1: SSH2_MSG_KEXINIT sent
debug1: SSH2_MSG_KEXINIT received
debug1: kex: server->client aes128-ctr hmac-sha1 none
debug1: kex: client->server aes128-ctr hmac-sha1 none
debug1: sending SSH2_MSG_KEXDH_INIT
debug1: expecting SSH2_MSG_KEXDH_REPLY
debug1: Server host key: RSA 16:27:ac:a5:76:28:2d:36:63:1b:56:4d:eb:df:a6:48
debug1: Host 'github.com' is known and matches the RSA host key.
debug1: Found key in /Users/XXXX/.ssh/known_hosts:1
debug1: ssh_rsa_verify: signature correct
debug1: SSH2_MSG_NEWKEYS sent
debug1: expecting SSH2_MSG_NEWKEYS
debug1: SSH2_MSG_NEWKEYS received
debug1: Roaming not allowed by server
debug1: SSH2_MSG_SERVICE_REQUEST sent
debug1: SSH2_MSG_SERVICE_ACCEPT received
debug1: Authentications that can continue: publickey
debug1: Next authentication method: publickey
debug1: Trying private key: /Users/XXXX/.ssh/id_rsa
debug1: Trying private key: /Users/XXXX/.ssh/id_dsa
debug1: No more authentication methods to try.
Permission denied (publickey).
接下来,eval "$(ssh-agent -s)"返回"Agent pid 2314", 然而ssh-add -l返回“代理没有身份。”< / p >

这就是我被困住的地方。

224317 次浏览

完整的细节在回答

总之,当ssh-add -l返回“代理没有身份”时,这意味着ssh使用的密钥(存储在诸如~/.ssh/id_rsa~/.ssh/id_dsa等文件中)要么丢失,要么身份验证代理ssh-agent不知道它们,要么它们的权限设置不正确(例如,world writable)。

如果你的键缺失或者你没有生成任何键,使用ssh-keygen -t rsa,然后ssh-add来添加它们。

如果键存在,但ssh-agent不知道(比如它们在非标准文件夹中),使用ssh-add /path/to/my-non-standard-ssh-folder/id_rsa来添加它们。

如果使用ssh-addssh-agent有问题,请参阅这个答案

试试这个:

ssh-add ~/.ssh/id_rsa

为我工作

我也曾被同样的问题困扰过一段时间,但最终还是解决了。

我的问题:我不能执行任何推送。我可以查一下&看到我的遥控器(使用git remote -v),但当我执行git push origin master时,它返回:Permission denied (publickey). fatal: Could not read from remote repository.,等等。

我是怎么解决的:

  • 我生成了一个键使用ssh-keygen -t rsa。输入密钥文件的名称(当被询问时)是无用的。
  • 然后我可以添加密钥(到git): ssh-add /Users/federico/.ssh/id_rsa,它成功返回Identity added: /Users/myname/.ssh/id_rsa (/Users/myname/.ssh/id_rsa)
  • 我把SSH密钥添加到github 使用此帮助页
  • 在尝试了Github的“权限拒绝公开密钥”帮助页面中的所有命令后,只有ssh-add -l命令有效/似乎有用(在运行了前面的步骤之后),它成功地返回了我的密钥。最后一步告诉你在你的GitHub页面上哪里检查你的公钥。这个命令将帮助您检查所有的键:ls -al ~/.ssh

然后推送命令终于起作用了!

我希望这对你有帮助! 祝大家好运

2019年macOS Sierra &高Sierra &卡特琳娜:

PS:大多数其他答案会让你创建一个新的ssh密钥…但你不需要这样做:)

https://openradar.appspot.com/27348363中详细描述,macOS/OS X till Yosemite曾经记住命令ssh-add -K <key>添加的SSH密钥

下面是我为了让它起作用而采取的4个步骤:

1: ssh-add ~/.ssh/PATH_TO_YOUR_SSH_PRIVATE_KEY (e.g. ~/.ssh/id_rsa)

2:~/.ssh/config中添加以下内容

Host *
AddKeysToAgent yes
UseKeychain yes
IdentityFile PATH_TO_YOUR_SSH_PRIVATE_KEY (e.g. ~/.ssh/id_rsa)

3:确保删除任何使用osxkeychain helper的gitconfig条目:

 https://github.com/gregory/dotfiles/commit/e38000527fb1a82b577f2dcf685aeefd3b78a609#diff-6cb0f77b38346e0fed47293bdc6430c6L48

4:重新启动您的终端,使其生效。

执行如下命令:

ssh-keygen -t rsa
ssh-add /Users/*yourUserNameHere*/.ssh/id_rsa**
pbcopy < ~/.ssh/id_rsa.pub**

去你的Github账户:https://github.com/settings/profile

1)单击:SSH和GPG键

2)新的SSH密钥和过去它在那里

3)添加SSH密钥

完成了!

首先你需要进入你的SSH目录
对于这个类型下面的命令在你的终端MAC或任何你在window

cd ~/.ssh

现在在ssh
在这里,您可以找到所有与您所有项目相关的SSH密钥/文件。现在,输入以下命令来显示是否有可用的SSH密钥

ls

这会显示所有可用的ssh,在我的例子中有两个
现在,您需要启动一个代理,在其中添加一个SSH。对于这种类型,以下命令

. txt
eval "$(ssh-agent -s)"

现在,最后但并非最不重要的是,您将在以下命令的代理类型中添加SSH

ssh-add ~/.ssh/your-ssh

取代

用你的ssh文件名替换你的ssh文件名,你从第二步ls command中得到了一个列表

这可能导致任何新终端,代理id是不同的。 您需要为代理

添加私钥
$ ssh-add <path to your private key>

我意识到的另一个元素是。ssh文件夹通常创建在Mac OS X /Users/的根文件夹中。如果您尝试从另一个文件夹使用ssh -vT git@github.com,即使您添加了正确的密钥,它也会给您一个错误。

您需要从当前文件夹中再次添加密钥(ssh-add '正确的路径到id_rsa')以成功进行身份验证(假设您已经将密钥上传到Git中的配置文件中)

经过长时间的斗争,我终于能够在Windows上解决这个问题,对我来说,用户环境变量GIT_SSH被设置为指向

“C: \程序文件(x86) \ \有WinScp腻子\ plink.exe”

它是和WinScp一起安装的。我将指针更改为使用默认的ssh.exe,附带git scm“C:\Program Files\Git\usr\bin\ssh.exe”

BitBucket的步骤:

如果你不想生成新的密钥,ssh - keygen跳过

ssh-keygen -t rsa

将公钥复制到剪贴板:

clip < ~/.ssh/id_rsa.pub

登录比特桶: 进入“查看配置文件”->设置-> SSH密钥(在“安全”页签中) 单击“添加密钥”, 将键粘贴到方框中,添加一个描述性标题

回到Git Bash:

ssh-add -l

你应该得到:

2048 SHA256:5zabdekjjjaalajafjLIa3Gl/k832A /c/Users/username/.ssh/id_rsa (RSA)

现在:git pull应该工作

这对我有用:
chmod 700 .ssh Chmod 600 .ssh/id_rsa . exe Chmod 644 .ssh/id_rsa.pub

.pub

然后输入以下内容: ssh-add ~/.ssh/id_rsa < / p >

我在从备份恢复硬盘驱动器后遇到了这个问题。

< >强劲我的问题: 我可以查一下&看到我的remote(使用git remote -v),但当我执行git push origin master时,它返回:Permission denied (publickey)。无法从远程存储库读取。< / p >

我已经有一个SSH文件夹和SSH密钥,通过终端(ssh-add /path/to/my-ssh-folder/id_rsa)添加它们成功添加了我的身份,但我仍然无法推送,仍然得到相同的错误。生成一个新密钥对我来说是一个坏主意,因为它与AWS上其他非常安全的权限绑定在一起。

事实证明,密钥和我的Github个人资料之间的链接已经断开。

<强>解决方案: 在配置文件>设置>中重新添加密钥到Github, SSH和GPG密钥解决了这个问题。< / p >

< >强也: 我的账户设置了双重认证。在这种情况下,如果终端请求凭据,使用您的用户名-而不是您的Github密码。对于2因素身份验证,您需要使用您的身份验证代码(对我来说,这是由我手机上的Authy生成的,我必须将其复制到终端的pw中)

对于我的mac Big Sur,根据上面的答案,以下步骤对我有用。

$ ssh-keygen -q -t rsa -N 'password' -f ~/.ssh/id_rsa
$ ssh-add ~/.ssh/id_rsa

并按照说明将ssh公钥添加到git hub;

https://docs.github.com/en/github/authenticating-to-github/adding-a-new-ssh-key-to-your-github-account

如果一切顺利, 您应该能够得到以下结果;

$ ssh -T git@github.com
Hi user_name! You've successfully authenticated,...

博士tl;

ssh-add # no parameter
# Identity added: /home/<user>/.ssh/id_rsa (user@host)

进一步的阅读

SSH - user -文件夹中需要两个文件:

ls ~/.ssh
id_rsa id_rsa.pub

如果文件不存在,输入命令ssh-keygen

现在启动ssh-agent:

eval `ssh-agent -s`

验证

ssh-add -l
# voila:
2048 SHA256:<key one> user@host (RSA)

奖金

用Github SHA256从你的用户设置检查本地SHA256 >SSH密钥。如果它们相等,你应该能够推/拉到/从Github使用您的密钥。

这也适用于我: Chmod 700 .ssh Chmod 600 .ssh/id_rsa . exe Chmod 644 .ssh/id_rsa.pub

.ssh/id_rsa.pub

然后,输入ssh-add ~/.ssh/id_rsa

有时检查~/.ssh/config可能很有用

应该是这样的

Host github.com
IdentityFile ~/.ssh/id_rsa

如果你链接了不同的键,id_rsa可以是不同的。

如果您正在使用Linux或Windows打开终端或cmd在目录你想要你的密钥。创建一对公私钥

 $ ssh-keygen -t ed25519 -C "your_email@example.com"

如果您正在使用不支持Ed25519算法的旧系统,请使用:

 $ ssh-keygen -t rsa -b 4096 -C "your_email@example.com"

生成公私算法密钥对。 输入要保存密钥的文件(/c/Users/YOU/.ssh/id_ALGORITHM):[按下Enter键,您希望您的私有公钥文件是的任何名称]

. txt

输入密码短语(空表示没有密码短语):[键入一个密码短语或输入没有密码短语]

再次输入相同的密码短语:[键入一个密码短语或输入不带密码的for]

现在,在Linux中

$ sudo cp <filename without .pub ending>  ~/.ssh

在Windows中,只需复制不带。pub结尾的<文件名。这个C:\Users\your_username\.ssh目录下的文件

然后

$ ssh-add ~/.ssh/<filename without .pub ending>

现在可能有用了!