2

我在 Linux 机器上运行一个使用 jcraft.jsch 库连接到外部 sftp 服务器的 Java 程序。代码如下所示:

JSch jsch = new JSch();
Session session = null;
Channel channel = null;  
ChannelSftp c = null;

session = jsch.getSession(ftpUserName, ftpHost, ftpPort);
session.setPassword(ftpPassword);

channel = session.openChannel("sftp");
channel.connect();
c = (ChannelSftp)channel;

fn = c.ls("/Inbox");
c.cd("/Inbox");  //-- this line throws an error

出于某种原因,当我运行更改目录命令“c.cd”时,我得到:

4: Folder not found: /drwxr-x--- 2 ftpadmin ftpadmin        0 Jan 01 1970 /Inbox

这很奇怪,因为该文件夹的列表(c.ls)没有引发异常。

此外,如果我从同一 Linux 服务器的命令行使用 lftp,我可以 cd 没有任何问题。

在此处输入图像描述

stacktrace 指向 cd 方法内的 _stat 方法。

    at com.jcraft.jsch.ChannelSftp.throwStatusError(ChannelSftp.java:2108)
    at com.jcraft.jsch.ChannelSftp._stat(ChannelSftp.java:1676)
    at com.jcraft.jsch.ChannelSftp.cd(ChannelSftp.java:290)
    at BW_Utilities.ftp.test.testFtpJsch(test.java:81)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)

当我从桌面使用 Filezilla 进行连接时,远程站点的文件夹结构如下所示:

在此处输入图像描述

我刚刚在我的 Windows 桌面机器上执行了相同的 Java 代码并且 cd 命令有效。(Windows 机器运行 JDK 1.6.0_29,而 Linux 服务器运行 JRE 1.6.0.27)

jsch 是否依赖于客户端操作系统级别的其他库?

知道如何继续解决此问题吗?

重要更新

我能够在我的开发机器上重现该错误。这与使用的 jsch 版本有关。linux 服务器使用 jsch-0.1.31,而开发机器使用 jsch-0.1.52。似乎导致错误的任何原因都已在 0.1.52 版中解决。呜!呜!最后!

谢谢

4

2 回答 2

2

升级到 jsch 版本 0.1.52 解决了这个问题。

于 2016-08-01T09:32:44.053 回答
1

尝试执行以下操作。

fn = c.ls("Inbox");
c.cd("Inbox");  
于 2016-07-31T00:12:50.380 回答