FTP是基于TCP的应用层协议,特殊点在于需要建立两个socket连接,一个是控制口,用于发送命令。一个是数据口,用于发送数据信息(如文件、目录结构等)。
数据连接: 服务器 (默认20端口) 连接 客户端 (>1024端口)
FTP
支持两种模式,主动模式(PORT)和被动模式(PASV)。主动模式和被动模式是指数据口的连接是由FTP服务器主动连接还是被动连接,实现的方式是通过控制口的命令。
主动模式由客户端发送“PORT 端口号 ”给服务器,则服务器主动连接客户端的“端口号”。在接收到需要返回数据的命令后,将数据信息从数据口传回。
被动模式由客户端发送“PASV”命令给服务器,则服务器回送IP地址+端口号,则客户端connect服务器发送回来的IP信息,等待数据的接收。
客户端和服务器通讯端口的连接信息如下
1、主动FTP:
命令连接:客户端 (>1024端口) 连接 服务器(默认21端口)
数据连接: 服务器 (默认20端口) 连接 客户端 (>1024端口)
2、被动FTP:
命令连接:客户端 (>1024端口) 连接 服务器 (默认21端口)
数据连接:客户端 (>1024端口) 连接 服务器 (>1024端口)
命令连接:客户端 (>1024端口) 连接 服务器 (默认21端口)
数据连接:客户端 (>1024端口) 连接 服务器 (>1024端口)
以下用TCP调试助手演示被动FTP的通信过程,并从FTP服务器下载一个文件。
借助工具TCP调试助手和FTPServer,FTP的服务器的IP为本机IP,设置账户名“
anonymous”,密码“123”以下是连接ftp服务器后返回的信息。
就不一一截图,将通信过程抄录如下:
client : USER anonymous\r\n
server: 331 Please specify the password.
client : PASS 123\r\n
server: 230 Login successful.
client : PASV\r\n
server: 227 Entering Passive Mode (192,168,2,103,240,99).
由此,服务器发送回来客户端可连接的数据端的IP为192.168.2.103,端口号为240*256+99=61539。则重开一个TCP调试助手,以客户端方式连接FTP服务器。
client :RETR 1.txt\r\n
server:150 Opening BINARY mode data connection for file transfer.
226 Transfer complete
连接FTP数据端的TCP调试助手则显示了文档FTP服务器根目录下1.txt的内容,并且在接收完成后,被强制关闭。
一般控制连接是一直保持到客户-服务器连接的全过程,但数据连接可以根据需要随时开启和结束,而通用的传输方式(UNIX环境下唯一的传输方式)是流方式,并且文件结尾以关闭数据为标志。这意味着每一个文件的传输或者目录列表等,都要建立一个全新的数据连接。这也能解释以上为何在数据端口传输完1.txt后,数据端口被强制关闭。
参考文档:
http://blog.csdn.net/kasagawa/article/details/6977567 FTP协议学习笔记