最近在做一个基于FTP协议传输文件的程序,将开发过程中碰到的一些问题及解决办法积累记录在这里备用
刚开始可能比较杂,先记录,以后再整理
1. FTP Server的选择
Server-U
Windows上最著名的Server-U,破解版满天飞,之前一直使用这个FTP-Server,功能强大,管理简单。
最开始搭建软件环境时就是使用Server-U,没想到用Java写的FTP客户端程序只能与Server成功连接完成1次操作,再操作就会提示错误
451 Another command is currently pending, please try again later.
网上关于此错误的信息不多,也没找到什么好的解决办法(有说防火墙的,有说路由的,我怀疑还是和FTP Server的服务模式设置有关,但我没找到好的调整办法),后来尝试更换FTP-Server软件,问题解决
Apache-FTP-Server
开源FTP Server,基于Apache MINA框架实现,目前版本1.0.5,因为之前使用Server-U出现客户端只能连接1次的问题,尝试更换Apache-FTP-Server,问题不再存在!!! 因为对FTP Server本身没什么复杂的管理要求(仅作为文件传输和存储用),就选它了,用起来也非常简单(依照官方Tutorial操作)
目前没有有很好的GUI管理工具,基本配置都是基于配置文件完成的,需要阅读文档了解其配置文件。关于用户的分配和权限控制也都是在配置文件中管理 user.properties
2. FTP Client的选择
Java开发用的FTP Client可选择还真是非常多,比较有代表性的 jFTP, Apache FTP Client...(网上对此类客户端API的介绍对比也很多)
这里我选择了jFTP, 目前最新版本1.53
优点:按晚上评价,可以完全满足FTP管理所有需求(功能已非常完备),开发使用简单
缺点:文档功夫做的不好,除了随包带的上传、下载示例,连JavaDoc都没提供,想深入研究估计要费点功夫
3. jFTP开发注意事项
1. 上传文件时,在服务端无法创建中文文件名。可以识别本地中文文件,但在服务端存储时应该使用英文文件名(可以用upload 方法中第二个参数 realname 直接为服务端文件重命名)
此处有人给出了解决办法,需要修改jftp源码,还未尝试
http://5linan.blog.163.com/blog/static/649038152009328101326908/
2. jFTP的断点续传功能实现:jFTP1.53版本对断点续传本身提供了完美的支持,使用起来也非常之简单(遗憾的是文档缺失,需要自己去翻源码理解)
只需在上传动作前开启断点续传设置即可
// 默认情况下此值是false,不支持断点续传机制 Settings.enableUploadResuming = true;
断点续传的实现代码中的 rawUpload 方法 [FTPConnection.java] 实现存在BUG,多处代码对文件大小的判断使用Integer来表达。在处理大文件(约大于2G)时转换会出错,如果应用程序需要传递的单个文件超过2G,建议调整FTPConnection源码
同理,断点续下的功能默认也是关闭的,需要手动开启
Settings.enableResuming = true;
3. 查看FPT Serve远程目录文件:就是最常用的 ls 命令,查看当前目录有哪些已存在文件。刚开始用jFTP开发时被这个功能卡住了,虽然 FTPConnection 提供 list() 方法,但奇怪的是没有返回值,不知道怎么用。查看源码才知道正确的使用方法,需要
// 需要先调用一次list conn.list(); String[] files = conn.sortLs(); String[] sizes = conn.sortSize(); for(int i = 0; i < files.length; i++) { System.err.println(files[i] + "\t" + sizes[i]); }