我的任务是将一些文件从服务器复制到本地,我搜索了很多有关连接库的信息,并找到了JSch。我使用了下面的代码,但是读取或移动文件花费了太多时间。我不知道它是否有效。
JSch jsch = new JSch();
Session session = null;
try {
// set up session
session = jsch.getSession("userName","hostIP");
// use private key instead of username/password
session.setConfig(
"PreferredAuthentications",
"publickey,gssapi-with-mic,keyboard-interactive,password");
jsch.addIdentity("***.ppk");
java.util.Properties config = new java.util.Properties();
config.put("StrictHostKeyChecking", "no");
session.setConfig(config);
session.connect();
// copy remote log file to localhost.
ChannelSftp channelSftp = (ChannelSftp) session.openChannel("sftp");
channelSftp.connect();
channelSftp.setInputStream(System.in);
channelSftp.setOutputStream(System.out);
System.out.println("shell channel connected....");
ChannelSftp c = (ChannelSftp) channelSftp;
System.out.println("done");
channelSftp.get("report.xml", "C:\\Users\\akrishnan");
channelSftp.exit();
} catch (Exception e) {
e.printStackTrace();
} finally {
session.disconnect();
}
是否存在可用于使用私钥文件(**。ppk)从Java代码连接服务器的库?
答案 0 :(得分:1)
这很可能是导致挂起的原因:
channelSftp.setInputStream(System.in);
channelSftp.setOutputStream(System.out);
为“ sftp”频道执行此操作会破坏所有内容。这没有道理。只需删除这两行。
检查官方JSch SFTP example –没有这样的电话。
有关使用JSch进行文件传输的正确代码,请参阅: SFTP file transfer using Java JSch。
强制性警告:请勿使用StrictHostKeyChecking=no
盲目接受所有主机密钥。那是一个安全漏洞。您失去了针对MITM attacks的保护。
有关正确(且安全)的方法,请参见:
How to resolve Java UnknownHostKey, while using JSch SFTP library?