这是我第一次访问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返回“代理没有身份”。

这就是我被困住的地方。


当前回答

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

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

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

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

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

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

其他回答

试试这个:

ssh-add ~/.ssh/id_rsa

为我工作

博士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)

奖金

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

2019年macOS Sierra & High Sierra & Catalina的答案:

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

正如https://openradar.appspot.com/27348363上详细描述的那样,macOS/OS X直到Yosemite曾经记住命令SSH -add -K <key>添加的SSH密钥

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

1: ssh-add ~/。ssh/PATH_TO_YOUR_SSH_PRIVATE_KEY(例如~/.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目录 对于这个类型,在你的终端MAC或任何你在window中使用的命令

cd ~/.ssh

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

ls

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

eval "$(ssh-agent -s)"

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

ssh-add ~/.ssh/your-ssh

取代

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

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

$ ssh-add <path to your private key>