这个问题在这里已有答案:
我使用ssh-keygen创建了一个新密钥对,并在服务器上添加了公钥。使用sftp -i private_key_file user@server
我可以成功打开与服务器的连接并放置文件。但是,当我尝试使用我收到的Ant scp任务时:
com.jcraft.jsch.JSchException: invalid privatekey: [B@5e9d5728
Ant脚本的相关部分:
<scp file="local-file.zip"
trust="true"
sftp="true"
todir="user@server:/dir/to/put/files"
keyfile="private_key_file"
verbose="true"/>
有没有人有想法?
看起来在最近的OpenSSH版本中(我在F29中安装了7.9)ssh-keygen生成了一种略有不同的密钥格式,现在从以下开始:
-----BEGIN OPENSSH PRIVATE KEY-----
代替:
-----BEGIN RSA PRIVATE KEY-----
我安装了1.50版本的JSch,它不喜欢新的格式。在密钥生成期间使用-m PEM
选项解决了我的问题:
ssh-keygen -t rsa -m PEM
在这个帖子中找到了解决方案:Invalid privateKey when using JGit and JSCH。谢谢和信誉去Natan和Roman Vottner!
(不确定是否还有新版本的JSch可以接受新的密钥格式。)