Commons VFS - 无法列出目录的内容

时间:2012-03-12 09:28:20

标签: java sftp apache-commons-vfs

我有Commons VFS的问题。我想使用SFTP连接到一个目录并列出它。这是代码:

FileSystemOptions opts = new FileSystemOptions();
SftpFileSystemConfigBuilder.getInstance().setStrictHostKeyChecking(opts, "no");
FileSystemManager fsManager = VFS.getManager();

FileObject sourceDir = fsManager.resolveFile(sourceUrl, opts);
FileObject targetDir = fsManager.resolveFile(config.get("to"));

for (FileObject sourceFile : sourceDir.getChildren()) { // here is the problem
    FileObject targetFile = fsManager.resolveFile(targetDir + "/" + nodeName + "_"
            + sourceFile.getName().getBaseName());
    logger.debug("Copying files. Source: " + sourceFile.getName().getPath() + " Target: "
            + targetFile.getName().getPath());
}

似乎fsManager正确解析了它,但getChildren()失败了。我发现sourceDirIMAGINARY类型;以下代码说明了

logger.debug(sourceDir.getType());

我检查了文件,它是一个普通的文件夹 - 不是链接或类似的东西。

错误

org.apache.commons.vfs2.FileNotFolderException: Could not list the contents of "sftp://path/to/dir" because it is not a folder.
    at org.apache.commons.vfs2.provider.AbstractFileObject.getChildren(AbstractFileObject.java:693)
    at pkg.services.impl.QuartzJobEventLog.downloadEventLogs(QuartzJobEventLog.java:64)
    at pkg.services.impl.QuartzJobEventLog.executeJob(QuartzJobEventLog.java:37)
    at pkg.services.impl.AbstractQuartzJob.execute(AbstractQuartzJob.java:25)
    at $QuartzJob_1360635dbcd.execute($QuartzJob_1360635dbcd.java)
    at org.quartz.core.JobRunShell.run(JobRunShell.java:203)
    at org.quartz.simpl.SimpleThreadPool$WorkerThread.run(SimpleThreadPool.java:520)

3 个答案:

答案 0 :(得分:12)

取决于哪种版本的VFS解决方案会有所不同。对于VFS 2.0,您必须在下面添加其他配置选项。

SftpFileSystemConfigBuilder.getInstance( ).setUserDirIsRoot(opts, false);

答案 1 :(得分:3)

根据documentation获取“目录内容”,SFTP文件系统不支持。

答案 2 :(得分:1)

当我们将VFS版本1.0升级到2.1并且发现文档提供正确的方向时面临同样的问题,因为我们需要设置下面的标志以避免使用来自用户主目录的相对路径。

默认情况下,路径相对于用户的主目录。这可以通过以下方式更改:

FtpFileSystemConfigBuilder.getInstance().setUserDirIsRoot(options, false);

https://commons.apache.org/proper/commons-vfs/filesystems.html#SFTP