关于这一点有很多例子,但是没有一个例子能够说明如何使用转换成字符串形式的.ppk公共/私有文件组件 byte[]
并与 JSch.addIdentity(String,byte[],byte[],byte[])
方法。有人能看看下面的方法,让我知道我哪里出错了。它不喜欢把字符串转换成 byte[]
. 出于安全原因,字符串没有完全显示出来,但我想你会明白我试图用这个来实现什么。不幸的是,由于我不能直接使用.ppk文件,我一直在使用字符串。
public void InitChannelSftp() throws JSchException {
JSch ssh = new JSch();
session_ = ssh.getSession(userName_, host_, port_);
session_.setConfig("StrictHostKeyChecking", "no");
String passPhrase= "trustNoOne";
String privateKey= "-----BEGIN RSA PRIVATE KEY-----\n" +
"hvbytegNktMU05bc3QlCrSs+YHkMAvZRkzcjaXDdcKDfSZyDqcFHfkup1N6CMDg4\n" +
"yZh0ou+7G8jDQtn29YoAO0tpEW4EGQiI6918iMk22012ytcsCnM80/hj1JbVa4St\n" +
"1StZKJtBYSu1bRZCpFPygditUGc9pZhDWfgDxLTzQdDMcmdvMb9AgpNKZAz8n0OR\n" +
"2tuGPAogbt8e48ad9H7IYuikhIqQU42DkrAqRPJDUZqP3gGdzwstuDPl1dwrRaCs\n" +
"vTynsEMDCjVjNyxRK9sbBO/BwFTaFRM2oN4BvCbfbQKyhRrXZ1gjNMv1P5GxchKj\n"+
"-----END RSA PRIVATE KEY-----\n";
String publicKey= "-----BEGIN SH2 PUBLIC KEY-----\n" +
"AAAAB3NzaC1yc2EAAAABJQAAAQEA6wXxLoqF70gkd2hURVlmq+iPCBPmkZ6IwCST\n" +
"nlxHY/Jc0izbn+6hyFUZmS53LN9CJyjjVvU+UAWapU2tTJKwO6aI8xcKmtBjdDeS\n" +
"GJgh6C+srGFlbNTXzV8sMmGEQirLyTOMwGviRFOhKn5/bUbqpw==\n" +
"-----BEGIN SH2 PUBLIC KEY-----\n"
ssh.addIdentity(
"Test Conn", privateKey.getBytes(StandardCharsets.US_ASCII),
publicKey.getBytes(StandardCharsets.US_ASCII), passPhrase.getBytes());
session_.connect();
channel_ = session_.openChannel("sftp");
channel_.connect();
ChannelSftp sftp_ = (ChannelSftp) channel_;
}
错误:
com.jcraft.jsch.jschexception:privatekey无效:[b@25be7b63
1条答案
按热度按时间kupeojn61#
以下私钥格式有效:
末尾不需要空行。
在腻子中,这是通过
Conversions > Export OpenSSH key
.