Apache Commons FTPClient无法检索某些文件

时间:2013-08-03 11:48:43

标签: java android ftp apache-commons apache-commons-net

我正在使用Apache Commons FTPClient从FTP服务器获取文件。这是设置:

 ftpClient.setDefaultPort(port);
            ftpClient.connect(server);
            ftpClient.login(user, password);
            ftpClient.enterLocalPassiveMode();
            ftpClient.setFileType(FTPClient.BINARY_FILE_TYPE);
            ftpClient.changeWorkingDirectory(path);

这是转移代码:

final FileOutputStream fileOutputStream = new FileOutputStream(tempFile);
                    final boolean result = ftpClient.retrieveFile(dirToList + aFile.getName(), fileOutputStream);
                    Log.i(TAG, "[" + (result ? "+" : "-") + "]");

我在日志中看到的内容:

I/SyncService( 4412): /Users/user1/Downloads/FtpSync/.idea/copyrightprofiles_settings.xml
I/SyncService( 4412): [-]
<...>
I/SyncService( 4412): /Users/user1/Downloads/FtpSync/footer.php
I/SyncService( 4412): [+]

所有php文件都已同步,并且所有xml文件都无法同步。 FTP服务器在我的本地笔记本上(Mac OS X默认ftp服务器,tnftpd 20100324 + GSSAPI)

为什么它不起作用?

3 个答案:

答案 0 :(得分:1)

首先,您应该始终在retrieveFile方法之后关闭输出流。您是否尝试在下载XML文件时更改FTP。{filetype}(虽然不是这样)?

答案 1 :(得分:1)

我在使用retrieveFile方法下载一些大文件时遇到了麻烦,它会在不抛出异常的情况下崩溃。最后我使用了retrieveFileStream方法,它为我解决了这个问题。

替换

status = mFTPClient.retrieveFile(srcFilePath, desFileStream);

使用

// import org.apache.commons.io.IOUtils;

InputStream inputStream = mFTPClient.retrieveFileStream(srcFilePath);
IOUtils.copy(inputStream, desFileStream);
outputStream.flush();
IOUtils.closeQuietly(desFileStream);
IOUtils.closeQuietly(inputStream);

//status = mFTPClient.completePendingCommand();
status = true;

completePendingCommand崩溃而没有为我抛出异常,因此它被注释掉了,但我认为应该在完成命令后调用它。

答案 2 :(得分:0)

使用此代码下载文件。

public boolean ftpDownload(String srcFilePath, String desFilePath)
    {
        boolean status = false;
        try {
            FileOutputStream desFileStream = new FileOutputStream(desFilePath);; //desfilepath where the file is to be stored
            status = mFTPClient.retrieveFile(srcFilePath, desFileStream);

            desFileStream.close();

            return status;
        } catch (Exception e) {
            Log.d(TAG, "download failed");
        }

        return status;
    }