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()); } } } }
