背景:
由于移动端业务的需求,应用到了ftp的文件上传功能,并考虑到移动端网络的不稳定性,需要加入断点续传功能。
详细介绍:
FTP,文件传输协议是TCP/IP协议组中的协议之一。包括两部分,ftp服务器和ftp客户端。FTP服务器用来存储文件,用户则使用ftp客户端通过ftp协议访问位于ftp服务器上的资源。另外,默认ftp协议使用TCP端口中的21端口。我想这个最基本的ftp知识,大家应该是知道的。
相对于其他协议,如http协议,ftp协议要复杂些,一般的通信协议建立一个socket连接,这条连接同时处理服务器端和客户端的连接命令和数据传输。而ftp则是将命令和数据分开传送的方法提高效率。
如下图所示,对ftp的整个大体的交互做了很好的描述。ftp服务器和ftp客户端之间存在着两条连接,一条控制连接,一条数据连接。
控制连接:
控制连接为ftp交互最主要的连接。从客户端登录到ftp服务器开始,到登出服务器的整个生命周期里面是始终存在的一条连接。如下图抓包所示为ftp一个控制连接的生命周期,从开始登录ftp服务器到ftp连接断开的整个过程。对于ftp控制连接来说,根据抓包情况可以很清楚的了解到当连接到ftp服务器成功后,ftp服务器会返回220状态,及后面的欢迎信息,这些信息不同服务器会有所不同,对于我们来说关系不是很大。之后的流程就是登陆服务器,登陆服务器会先输入用户名,服务器此时会返回230状态,意思是需要输入密码,当输入密码正确后,登陆返回200,状态,返回成功。从中可以看出一些规律来,服务器和客户端都是一应一答的消息模式。这是单纯的控制。直到连接被断开,ftp客户端和ftp服务器的交互结束。</