1. FTP服务器设置了匿名访问, 使用 ftpClient.listFiles() 无法获得文件列表问题
ftpClient.login("anonymous", ""); //使用用户名为"anonymous",密码为空,进行登录即可
2. ftpClient.retrieveFile()方法下载文件,可以下载成功,但文件大小为0
原来是每次调用该方法,outputStream 文件输出流都要close一下,我是多次下载文件,但只是在最后关闭一下,导致只有最后一个文件下载完整,前面几个文件没有完全下载下来。
下载代码如下:
public boolean download() {
FTPClient ftpClient = connectFtpServer();
if (ftpClient == null || !ftpClient.isConnected()) {
logger.info("ftp connect fail------>");
return false;
}
OutputStream outputStream = null;
try {
ftpClient.changeWorkingDirectory(remoteDir);
FTPFile[] ftpFiles = ftpClient.listFiles();
if(ftpFiles.length==0)
return false;
//遍历当前目录下的文件
String fileName;
for (FTPFile ftpFile : ftpFiles) {
if(ftpFile.isDirectory())
continue;
fileName = ftpFile.getName();
outputStream = new FileOutputStream(localDir+ "\\"+ fileName);//创建文件输出流
Boolean isSuccess = ftpClient.retrieveFile(new String(fileName.getBytes("GB2312"),"ISO-8859-1"), outputStream); //下载文件
if (!isSuccess) {
logger.error("download file 【%s】 fail", fileName);
}
outputStream.flush();
outputStream.close();
}
ftpClient.logout();
logger.info("download file success");
return true;
} catch (IOException e) {
logger.error("download directory 【%s】 fail ------->>>%s", remoteDir, e.getCause().getMessage());
return false;
} finally {
if (ftpClient.isConnected()) {
try {
ftpClient.disconnect();
} catch (IOException e) {
logger.error("disconnect fail ------->>>%s", e.getCause().getMessage());
}
}
if (outputStream != null) {
try {
outputStream.close();
} catch (IOException e) {
logger.error("outputStream close fail ------->>>%s", e.getCause().getMessage());
}
}
}
}