公钥被拒绝,但接受了ssh密钥

时间:2013-09-28 08:35:40

标签: git github ssh

我在推送git时遇到了麻烦(或者更确切地说,git在我身上遇到了麻烦),就像我git push我收到错误一样:

Permission denied (publickey).
fatal: The remote end hung up unexpectedly

我已经为此查看了git的help page,但他们建议的所有'测试'都在传递,包括通过运行$ ssh -vT git@github.com检查是否正在使用正确的密钥。这似乎是大多数人根据我在SO上看到的帖子搁浅的地方,但它对我有用。这是我输错的情况下的输出。

OpenSSH_5.2p1, OpenSSL 0.9.8r 8 Feb 2011
debug1: Reading configuration data /etc/ssh_config
debug1: Connecting to github.com [192.30.252.130] port 22.
debug1: Connection established.
debug1: identity file /Users/charliekim/.ssh/identity type -1
debug1: identity file /Users/charliekim/.ssh/id_rsa type 1
debug1: identity file /Users/charliekim/.ssh/id_dsa type -1
debug1: Remote protocol version 2.0, remote software version OpenSSH_5.9p1 Debian-5ubuntu1+github5
debug1: match: OpenSSH_5.9p1 Debian-5ubuntu1+github5 pat OpenSSH*
debug1: Enabling compatibility mode for protocol 2.0
debug1: Local version string SSH-2.0-OpenSSH_5.2
debug1: SSH2_MSG_KEXINIT sent
debug1: SSH2_MSG_KEXINIT received
debug1: kex: server->client aes128-ctr hmac-md5 none
debug1: kex: client->server aes128-ctr hmac-md5 none
debug1: SSH2_MSG_KEX_DH_GEX_REQUEST(1024<1024<8192) sent
debug1: expecting SSH2_MSG_KEX_DH_GEX_GROUP
debug1: SSH2_MSG_KEX_DH_GEX_INIT sent
debug1: expecting SSH2_MSG_KEX_DH_GEX_REPLY
debug1: Host 'github.com' is known and matches the RSA host key.
debug1: Found key in /Users/charliekim/.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: SSH2_MSG_SERVICE_REQUEST sent
debug1: SSH2_MSG_SERVICE_ACCEPT received
debug1: Authentications that can continue: publickey
debug1: Next authentication method: publickey
debug1: Offering public key: /Users/charliekim/.ssh/id_rsa
debug1: Server accepts key: pkalg ssh-rsa blen 277
debug1: Authentication succeeded (publickey).
debug1: channel 0: new [client-session]
debug1: Requesting no-more-sessions@openssh.com
debug1: Entering interactive session.
debug1: Remote: Forced command.
debug1: Remote: Port forwarding disabled.
debug1: Remote: X11 forwarding disabled.
debug1: Remote: Agent forwarding disabled.
debug1: Remote: Pty allocation disabled.
debug1: Remote: Forced command.
debug1: Remote: Port forwarding disabled.
debug1: Remote: X11 forwarding disabled.
debug1: Remote: Agent forwarding disabled.
debug1: Remote: Pty allocation disabled.
PTY allocation request failed on channel 0
Hi **! You've successfully authenticated, but GitHub does not provide shell access.
                                                                                            debug1: client_input_channel_req: channel 0 rtype exit-status reply 0
debug1: client_input_channel_req: channel 0 rtype eow@openssh.com reply 0
debug1: channel 0: free: client-session, nchannels 1
Connection to github.com closed.
Transferred: sent 2496, received 3048 bytes, in 0.3 seconds
Bytes per second: sent 9462.3, received 11554.9
debug1: Exit status 1

以下是.git/config

中的远程网址
[remote "origin"]
    url = ssh://github.com/[user]/[repo].git
    fetch = +refs/heads/*:refs/remotes/origin/*

1 个答案:

答案 0 :(得分:4)

您的git配置缺少用户,因此git正在尝试以您身份(charliekim)进行身份验证,而不是作为Github期望的用户git进行身份验证。

使用正确的用户,您应该可以连接:

[remote "origin"]
    url = ssh://git@github.com/[user]/[repo].git
    fetch = +refs/heads/*:refs/remotes/origin/*
相关问题