SFTP (Windows with WinSSHD ) に問題があります。Apache Commons VFSでフォルダーにファイルを書き込もうとしています。ローカル SFTP ではアップロードに問題はありませんが、2 番目の SFTP では常に以下のエラーが発生します。
FTP は次のようになります。
「alis」フォルダにアップロードする必要があります。奇妙なのは、ユーザー/グループと 770 の権限がないことです。ただし、FileZilla を使用すると、ファイルのアップロードは正常に機能します (同じログインが使用されます)。
フォルダー「alis」で「manager.resolveFile()」を実行し(このフォルダーにアップロードしようとします)、「.getType()」を印刷すると、「ファイル」という情報が得られますが、期待どおりの「フォルダー」ではありません。
VFS がフォルダーをファイルとして認識する理由、またはアップロードが機能しない理由を知っている人はいますか?
ファイルを SFTP にアップロードするときの例外:
Exception in thread "main" java.lang.RuntimeException: org.apache.commons.vfs2.FileSystemException: Could not copy "file:///D:/Test/test.txt" to "sftp://user:***@host/.../alis/test.txt".
at test.Test.upload(Test.java:77)
at test.Test.main(Test.java:22)
Caused by: org.apache.commons.vfs2.FileSystemException: Could not copy "file:///D:/Test/test.txt" to "sftp://user:***@host/.../alis/test.txt".
at org.apache.commons.vfs2.provider.AbstractFileObject.copyFrom(AbstractFileObject.java:1062)
at test.Test.upload(Test.java:73)
... 1 more
Caused by: org.apache.commons.vfs2.FileSystemException: Could not create folder "sftp://user:***@host/.../alis" because it already exists and is a file.
at org.apache.commons.vfs2.provider.AbstractFileObject.createFolder(AbstractFileObject.java:968)
at org.apache.commons.vfs2.provider.AbstractFileObject.getOutputStream(AbstractFileObject.java:1424)
at org.apache.commons.vfs2.provider.DefaultFileContent.getOutputStream(DefaultFileContent.java:461)
at org.apache.commons.vfs2.provider.DefaultFileContent.getOutputStream(DefaultFileContent.java:441)
at org.apache.commons.vfs2.FileUtil.copyContent(FileUtil.java:111)
at org.apache.commons.vfs2.provider.AbstractFileObject.copyFrom(AbstractFileObject.java:1053)
... 2 more
ソースコード: (例を実行するには「jsch-0.1.50.jar」が必要です)
import java.io.File;
import org.apache.commons.vfs2.FileObject;
import org.apache.commons.vfs2.FileSystemException;
import org.apache.commons.vfs2.FileSystemOptions;
import org.apache.commons.vfs2.Selectors;
import org.apache.commons.vfs2.impl.StandardFileSystemManager;
import org.apache.commons.vfs2.provider.sftp.SftpFileSystemConfigBuilder;
/**
*
* @author thbe
*/
public class Test {
/**
* @param args the command line arguments
*/
public static void main(String[] args) {
upload("host", "user", "password", "D:/Test/test.txt", "/../alis/test.txt");
}
public static FileSystemOptions createDefaultOptions()
throws FileSystemException {
// Create SFTP options
FileSystemOptions opts = new FileSystemOptions();
// SSH Key checking
SftpFileSystemConfigBuilder.getInstance().setStrictHostKeyChecking(
opts, "no");
// Root directory set to user home
SftpFileSystemConfigBuilder.getInstance().setUserDirIsRoot(opts, true);
// Timeout is count by Milliseconds
SftpFileSystemConfigBuilder.getInstance().setTimeout(opts, 10000);
SftpFileSystemConfigBuilder.getInstance().setPreferredAuthentications(opts, "publickey,keyboard-interactive,password");
return opts;
}
public static void upload(String hostName, String username,
String password, String localFilePath, String remoteFilePath) {
File f = new File(localFilePath);
if (!f.exists()) {
throw new RuntimeException("Error. Local file not found");
}
StandardFileSystemManager manager = new StandardFileSystemManager();
try {
manager.init();
// Create local file object
FileObject localFile = manager.resolveFile(f.getAbsolutePath());
System.out.println("open remote File");
FileObject remoteFile = manager.resolveFile(
createConnectionString(hostName, username, password,
remoteFilePath), createDefaultOptions());
System.out.println("exists:"+remoteFile.exists());
System.out.println("type:"+remoteFile.getType());
System.out.println("URL:"+remoteFile.getURL());
System.out.println("copy to remote File");
remoteFile.copyFrom(localFile, Selectors.SELECT_SELF);
System.out.println("File upload success");
} catch (Exception e) {
throw new RuntimeException(e);
} finally {
manager.close();
}
}
public static String createConnectionString(String hostName,
String username, String password, String remoteFilePath) {
// result: "sftp://user:123456@domainname.com/resume.pdf
return "sftp://" + username + ":" + password + "@" + hostName + "/"
+ remoteFilePath;
}
}