Apache Commons Net——FTP

Apache Commons Net库包含了一组网络实用程序和协议实现。支持的协议包括Echo,Finger,FTP, NNTP,NTP,POP3(S),SMTP(S), Telnet, Whois等。

FTP功能支持的文件类型包括FTP.ASCII_FILE_TYPE和FTP.BINARY_FILE_TYPE。

POM中的依赖配置:

     
        commons-net
        commons-net
        3.7
     

FTPClient

FTPClient封装了从FTP服务器存储和检索文件所需的所有功能。这个类处理了与FTP服务器交互的所有底层细节,并提供了一个方便的高级接口。和其他从SocketClient派生的所有类一样,在执行任何操作之前,必须使用connect连接到服务器,然后通过FTP reply code来确认是否连接成功。在完成交互之后,必须断开连接。

需要注意,如果某个客户端连接空闲时间超过配置(通常为900秒),FTP服务器会提前关闭连接。在数据传输期间,数据连接很忙,但是控制连接空闲。FTP服务器知道控制连接正在使用,所以不会因为它缺乏活动而将其关闭, 但是,网络路由器并不了解控制连接和数据连接之间的关联性。一些路由器会将控制连接视为空闲,从而将其断开。

一种解决方案就是发送安全命令,例如NNOP,重置路由器的空闲计时器,例如:
ftpClient.setControlKeepAliveTimeout(300);//将超时设为5分钟。
这将导致文件上传/下载方法大约每5分钟发送一个NOOP。

FTPClient的默认设置是:
1.FTP.ASCII_FILE_TYPE,
2.FTP.NON_PRINT_TEXT_FORMAT
3.FTP. STREAM_TRANSFER_MODE,
4.FTP.FILE_STRUCTURE。

常用代码

     FTPClient  ftp = new FTPClient();
     FTPClientConfig config = new FTPClientConfig();
     //......设置
      ftp.configure(config);
      boolean error = false;
      try {
          int reply;
          String server = "ftp.example.com";
          ftp.connect(server);       
          reply=ftp.getReplyCode();
          if(!FTPReply.isPositiveCompletion(reply)){
                 ftp.disconnect(); // 连接失败
           }else{
                ftp.login(username, password);
                f.changeWorkingDirectory(remotePath);
                FTPFile [] files = f.listFiles();
                //......
               
           }

      }catch(IOException e){
        //......
     }finally{
            if(ftp.isConnected()){
                    try{
                        ftp.disconnect();
                    }catch(IOException e){
                         //......
                    }
            }
     }

你可能感兴趣的:(Apache Commons Net——FTP)