iOS中FTP被动模式开发总结
最近接手的项目中采用FTP来现实文件的上传下载,但是接手的项目中程序并不能正常的运行,于是将最近研究的问题记录一下。
- 问题一:FTP工作模式
FTP的工作模式分为主动和被动模式。
简单的说,主动模式是客户端链接服务端之后,服务端使用数据端口主动链接客户端发送数据。
被动模式是,客户端链接服务端后,客户端发送命令到服务端,客户端主动通过数据端口和命令端口来发送命令和收发数据。
这里有一篇关于FTP知识很好的文章可以参考
实现方式:
主动模式的第三方实现在Github上面一大把。
被动模式的第三方没有找到的有。
注意:(FTP服务包括vsftpd和proftpd两种)
服务端采用被动模式,客户端在内网环境下采用主动模式开发,收发数据正确,切换到外网环境下就会失败,无法登录链接到FTP服务器。
服务端采用主动模式,客户端在内网环境下开发没有问题,切换到外网环境可能就会失败,查询原因是防火墙的锅(防火墙可能拦截)。
- FTP被动模式的实现
由于网上资料稀少,后面通过对《Professional.iOS.Programming》一书中FTP章节的学习,就对FTP客户端的实现有了比较清楚的认识。
关于服务端FTP的配置问题,如果公司有后端人员配合修改是最好的。
推荐一篇关于服务端FTP配置介绍的文章 传送门
项目中对客户端配置比较重要的配置,其他请参考上述链接
TimeoutIdle -->设置空闲连接超时时钟
TimeoutLogin --> 设置空闲登陆超时时钟
TimeoutNoTransfer --> 设置当没有数据传输时的超时时钟
TimeoutStalled --> 设置被阻塞的下载的超时时钟
MaxClientsPerHost -->限制客户端机器最多的连接数
问题:
该书中关于FTP的Demo暂时只支持操作单个文件,项目中需要实现对文件的批量操作。
实现方案:
将需要下载的资源放到一个队列中保存,然后依次从队列中取出处理。
实际过程中遇到的问题:
1、当资源比较多的时候,客户端会出现阻塞的问题
这个问题跟FTP服务器配置有关系 MaxClientsPerHost
Connection refused (MaxClientsPerHost 50)
2、当下载任务的时候,会出现socket阻塞60s左右的问题
一般出现于向FTP服务器发送密码命令的时候
SocketStream write error [0x600002fcf0c0]: 1 60
解决方案:当发生阻塞的时候,停止本次操作,重新开启一个新的线程来进行后续任务的操作,本次任务会失败,后续通过代码将本次失败的操作加到任务队列中,或者友好的提示用户重新下载。
3、在进行上传任务的时候,数据流上传成功,此时关闭命令流和数据流,有几率导致上传的文件并不存在
解决方案:1、数据流处理完成之后延时关闭。2、关闭之后利用代码检查FTP服务端刚上传的文件是否存在
支持单个文件和多个文件的上传下载操作。