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

这就是我被困住的地方。


当前回答

首先,您需要进入SSH目录 对于这个类型,在你的终端MAC或任何你在window中使用的命令

cd ~/.ssh

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

ls

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

eval "$(ssh-agent -s)"

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

ssh-add ~/.ssh/your-ssh

取代

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

其他回答

博士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使用您的密钥。

执行如下命令:

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-add ~/.ssh/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):

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

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

现在,在Linux中

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

在Windows中,只需将<filename不带.pub结尾的>文件复制到C:\Users\your_username\。ssh目录

然后

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

现在可能有用了!

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

$ ssh-add <path to your private key>