我正在使用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)
为什么它不起作用?
答案 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;
}