Ошибка загрузки файла в SFTP (Apache VFS)

У меня проблема с SFTP (Windows с WinSSHD). Я пытаюсь записать файл в папку с Apache Commons VFS. На локальном SFTP у меня нет проблем с загрузкой, но на втором SFTP я всегда получаю ошибку ниже.

FTP выглядит так:

Мне нужно загрузить в папку "Алиса". Что странно, так это то, что у него нет пользователя / группы и 770 прав. Тем не менее, с FileZilla загрузка файла работает нормально (используется тот же логин).

Делая "manager.resolveFile()" в папке "alis" (я пытаюсь загрузить в эту папку) и печатая ".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;
    }
}

3 ответа

Решение

Мы использовали другой способ подключения и загрузки файлов на некоторые SFTP:

public static void main(String[] args) {
    putFile("user", "host", "passwd", "/../test.txt", "C:/test.txt");
}
public static void putFile(String username, String host, String password, String remotefile,     String localfile){
    JSch jsch = new JSch();
    Session session = null;
    try {
          session = jsch.getSession(username, host, 22);
          session.setConfig("StrictHostKeyChecking", "no");
          session.setPassword(password);
          session.connect();

          Channel channel = session.openChannel("sftp");
          channel.connect();
          ChannelSftp sftpChannel = (ChannelSftp) channel;
          sftpChannel.put(localfile, remotefile);
          sftpChannel.exit();
          session.disconnect();
     } catch (JSchException e) {
          e.printStackTrace();  
     } catch (SftpException e) {
          e.printStackTrace();
     }
}

Этот подход должен работать с любым SSH (SFTP) и не запрашивать какую-либо информацию для входа в систему или другие блокирующие вещи.

Ты упомянул:

770 rights but no user and no group.

"Другие" люди не имеют права пользоваться каталогом. В каталоге нет пользователя или группы, поэтому ваш SFTP-клиент мог не работать из-за недостаточных прав доступа.

Что произойдет, если вы назначите ему пользователя / группу?

Я столкнулся с той же проблемой. Вы пытаетесь создать папку в том же месте, и файл существует в том же месте с тем же именем.

Другие вопросы по тегам