几个星期以来,我不能从远程存储库中拉或推到远程存储库中。我以为这是在升级到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可执行文件。

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


当前回答

我通过在命令中的SSH -agent中添加我的SSH私钥来解决这个问题:

$ ssh-add -K ~/.ssh/id_rsa

设置设置——>版本控制——> Git,然后,在SSH可执行下拉菜单中,选择本机

其他回答

不是解决方案/变通方法,但可能是对“可能是什么问题”的回答:

Gitlab和“在ssh库中构建的jetbrains”不能很好地一起工作。库希望使用基于SHA1的密钥交换算法,而gitlab(默认)只允许基于SHA2的密钥交换算法。

至少TeamCity (https://youtrack.jetbrains.com/issue/TW-47704)报告了这一点。

事实上,它也可能是你在IntelliJ中的拉/推问题的原因,也是我在PhpStorm中的推问题的原因,这是基于假设jetbrains为所有软件使用相同的“内置库”。

问题在我的电脑里解决了。 设置——>版本控制——>Git,然后,在SSH可执行下拉菜单中,选择内置选项。

安装旧版本的git,比如2.14.2。 它的工作很好!

设置——>版本控制——> Git,然后,在SSH可执行下拉菜单中,选择本机

如果这没有帮助,请确保您的本地ssh和git客户端是最新的版本。

我尝试了上面所有的解决方案(本机,更改VCS存储库的url,更新Git,更新IDEA,使缓存无效),但没有帮助我。最后我找到了适合我的解决办法。

解决方案:我关闭了Idea,并将文件~\.IntelliJIdea20xx.x\config\options\git.xml的内容替换为:

<application>
  <component name="Git.Application.Settings">
    <option name="SSH_EXECUTABLE" value="IDEA_SSH" />
  </component>
</application>

然后我开始了IDEA,尝试签出SSH GIT存储库,它可以工作,现有的项目也可以工作。有趣的事实是,当我切换到本机的想法设置,存储库不工作。

如果SSH不起作用,请确保在IntelliJ设置中选择“Native”后,将git存储库的链接更改为HTTPS选项。