几个星期以来,我不能从远程存储库中拉或推到远程存储库中。我以为这是在升级到IntelliJ IDEA 14时发生的,但我也可以用IDEA 13.1.5重现这个问题。

工具提示说 “获取失败 致命:无法从远程存储库读取。"

版本控制选项卡中的异常为

14:02:37.737: cd C:\dev\project
14:02:37.737: git -c core.quotepath=false fetch origin --progress --prune
java.io.IOException: Padding in RSA public key!
    at com.trilead.ssh2.signature.RSASHA1Verify.decodeSSHRSAPublicKey(RSASHA1Verify.java:37)
    at com.trilead.ssh2.KnownHosts.addHostkey(KnownHosts.java:98)
    at com.trilead.ssh2.KnownHosts.initialize(KnownHosts.java:414)
    at com.trilead.ssh2.KnownHosts.initialize(KnownHosts.java:440)
    at com.trilead.ssh2.KnownHosts.addHostkeys(KnownHosts.java:137)
    at org.jetbrains.git4idea.ssh.SSHMain.configureKnownHosts(SSHMain.java:462)
    at org.jetbrains.git4idea.ssh.SSHMain.start(SSHMain.java:155)
    at org.jetbrains.git4idea.ssh.SSHMain.main(SSHMain.java:137)
fatal: Could not read from remote repository.
Please make sure you have the correct access rights
and the repository exists.

使用IntelliJ内置终端,执行git -c core。Quotepath =false fetch origin -progress -prune,它就像它应该的那样工作。

根据堆栈跟踪,我的KnownHosts似乎有问题,所以我从~/删除了我们的git服务器。ssh/known_hosts,希望IntelliJ再次插入它。但是当通过UI更新时,问题仍然出现,并且在known_hosts中没有写新的条目;考虑对文件进行缓存,我重新启动了IntelliJ,但没有成功。

当从终端进行另一次git取回时,现在我被问到是否要永久添加服务器。之后,它再次被写入known_hosts,但IntelliJ仍然不让我更新我的项目。

我还没有在网上找到任何关于这种行为的信息,所以我猜这不是新的IntelliJ版本的已知错误。尽管如此,我更新到14.0.2,但问题仍然存在。

IntelliJ被配置为使用内置的SSH可执行文件。

有人知道问题出在哪里吗?


当前回答

我开始得到不能从远程存储库错误最近与我的github存储库工作时。我的规格:

IntelliJ IDEA 2017.3.4(终极版) 设置->版本控制-> Git -> SSH可执行文件->内置 Fedora Linux

当然,这些问题只发生在试图从IDE中推/拉/取等时-从命令行执行相同的命令就像一个咒语。

这个方法对我很有效

我不想从内置SSH可执行文件切换到本地,主要是因为我的本地SSH客户端在我试图与远程存储库同步时要求我输入密码。

我通过从SSH远程URL切换到HTTPS URL解决了这个问题。根据这个GitHub帮助页面-建议使用HTTPS URL而不是SSH URL。

远程URL从SSH更改为HTTPS

在IntelliJ IDEA打开VCS -> Git -> Remotes…,选择包含“原点”的行,并按下编辑按钮。如果你在GitHub上托管你的存储库,从以下替换你的SSH URL:

git@github.com:USERNAME/REPOSITORY.git

to:

https://github.com/USERNAME/REPOSITORY.git

你也可以从你的GitHub存储库主页获得你的HTTPS URL -点击“克隆或下载”按钮,然后点击“使用HTTPS”链接来显示你的存储库的HTTPS URL:

更新2018-03-13

JetBrains刚刚发布了IntelliJ IDEA 2017.3.5,包括SSH访问GitHub的修复- https://blog.jetbrains.com/idea/2018/03/intellij-idea-2017-3-5-fix-for-ssh-access-to-github/

其他回答

我简单地解决了这个问题,确保我有正确的git SSH url没有任何尾随空格:

git@github.com:USERNAME/REPOSITORY.git

@yabin ya说的是一个很酷的解决方案,只是提醒你:如果你仍然遇到同样的问题,去设置-版本控制- github,并使用ssh取消克隆git存储库。

您需要生成一个新的SSH密钥并将其添加到您的SSH -agent。你应该点击这个链接。

在您创建公钥并将其添加到您的github帐户后,您应该在Intellij Idea中的设置->版本控制-> Git -> SSH可执行文件下使用内置(不是本机)选项。

IntelliJ的内置SSH客户端似乎散列了它的known_hosts,但我使用的那个客户端主机名是明文形式的。

当我删除文件并让IntelliJ创建一个新的文件时,它只使用我的(散列的)GitLab服务器,没有其他任何东西,它工作了。

在IntelliJ中,也不可能将它们混合在一起——将一些非散列项与散列项放在一起。因此,您必须配置其他SSH客户机以使用散列主机。

进入首选项>版本控制> Git。确保SSH可执行文件设置为“本机”。(如果已经是这样,切换到“内置”,应用它,然后再次切换回“原生”。)

如果这不能解决你的问题,我建议下载一个Git客户端,如GitHub客户端(免费桌面应用程序),并尝试通过应用程序同步你的项目。然后返回IntelliJ,检查它是否工作。