传输文件时,JSch SFTP代码挂起

时间:2019-03-18 16:17:49

标签: java ssh jsch

我的任务是将一些文件从服务器复制到本地,我搜索了很多有关连接库的信息,并找到了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代码连接服务器的库?

1 个答案:

答案 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?