大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。
Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺
报错
在 Pycharm中 用密钥登录的时候会报错
[1/4/2021 10:54 AM] Upload to gpu11-188 failed: keypair ‘C:\Users\xx.ssh\id_rsa’ is corrupt or has unknown format.
Only SSH2 keys in OpenSSH format (DSA, RSA or ECDSA) or PuTTY Private Key *.ppk keys are supported.
Error message: invalid privatekey: [B@7b3e701a
这是 id_rsa 格式不对造成的
问题分析
我记得之前是用RSA的加密方式生成了密钥,但是打开自己使用的密钥文件才的发现,
-----BEGIN OPENSSH PRIVATE KEY-----
是 openSSH 方式的密钥。
之前 RSA 方式的密钥文件的开头是
-----BEGIN RSA PRIVATE KEY-----
原来问题出在,使用命令 ssh-keygen -t rsa
生成ssh,默认是以新的格式生成,id_rsa的第一行变成了“BEGIN OPENSSH PRIVATE KEY” 而不再是“BEGIN RSA PRIVATE KEY”,这是一种新的密钥格式, 而且很多软件对这种格式的密钥都是不支持的。
所以需要把openSSH 方式的密钥转换成SSH2
这时候就不得不把私钥转换成RSA – PEM格式。然而ssh-keygen
并不提供这种格式转换的功能。
解决方案
1. 把 id_rsa 转换成 PuTTY
安装WinSCP
打开WinSCP
选择密钥登录
会自己检测然后生成 PuTTY 格式的密钥
2. id_rsa 转换成 RSA
安装 WinSCP
还是在 WinSCP 里面点击 【工具】,打开 PuTTY Key Generator
load ppk 密钥
load 之后导出成RSA格式的密钥
然后打开生成的新的密钥文件就可以发现,文件第一行显示的是
-----BEGIN RSA PRIVATE KEY-----
Finish !
参考
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/175363.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...