玩明白了以太网2的二层数据格式, ip格式 tcp/udp个时候, 需要玩一玩一些有用的基于这些已上的协议数据了. 如 dhcp ftp等.比较有趣.
ftp协议
分控制连接21端口 和数据连接 20端口
数据连接站在服务端角度来讲分两种模式: 主动模式(服务端主动用自己的20端口去连客户端,适合防火墙)
被动模式(服务端被动等客户端来连服务端的一个随机端口.)
每个协议都有控制层面(对应控制报文),和数据层面(对应的传输数据,有些只有控制层面,如dhcp不需要传数据)
FTP服务端会监听2个端口, 控制进程20,数据进程21(主动模式)
数据连接,站在服务器角度,有2种模式:
主动模式:ftp server从20端口主动向客户端发起连接,由于源端口固定,所以适用于模式防火墙模式.
被动模式:ftp server被动等待客户端来连我的这个端口(控制连接后会告知会将passive ip/port告知了客户端)
一般情况下默认都是被动模式
ftp两种模式
原图和两枚ftp数据包: https://github.com/lannyMa/scripts/tree/master/pkgs/ftp
主动模式数据交互过程
14.1 客户端 14.128服务端
-
建立控制连接,3次握手, 客户端连服务端21端口
-
待连接建立后,客户端告知服务端 active ip/port
-
服务端主动和客户端建立数据连接(站在服务端角度,是服务端主动去找客户端)
-
传输数据
-
断开数据连接
-
断开控制连接
被动模式数据交互过程
-
客户端主动去和服务端建立控制连接
-
服务端告知客户端passive mode /ip/port
-
客户端主动去和服务端建立数据连接(站在服务端角度,是服务端被动等客户端)
-
客户端和服务端之间断开数据连接
-
客户端和服务端之间断开控制连接