Java FTPClient 使用问题总结

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

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值