tcp,全称transfer control protocol,中文名为传输控制协议,它工作在osi的传输层,提供面向连接的可靠传输服务。
tcp的工作主要是建立连接,然后从应用层程序中接收数据并进行传输。tcp采用虚电路连接方式进行工作,在发送数据前它需要在发送方和接收方建立一个连接,数据在发送出去后,发送方会等待接收方给出一个确认性的应答,否则发送方将认为此数据丢失,并重新发送此数据。
下面我们来介绍一下tcp的报头结构和相关工作原理:
tcp报头总长最小为20个字节,其报头结构如下图(图1)所示;
比特0 比特15 比特16 比特31
源端口(16) | 目的端口(16) | ||
序列号(32) | |||
确认号(32) | |||
tcp偏移量(4) | 保留(6) | 标志(6) | 窗口(16) |
校验和(16) | 紧急(16) | ||
选项(0或32) | |||
数据(可变) |
图1 tcp报头结构
源端口:指定了发送端的端口
目的端口:指定了接受端的端口号
序号:指明了段在即将传输的段序列中的位置
确认号:规定成功收到段的序列号,确认序号包含发送确认的一端所期望收到的下一个序号
tcp偏移量:指定了段头的长度。段头的长度取决与段头选项字段中设置的选项
保留:指定了一个保留字段,以备将来使用
标志:syn、ack、psh、rst、urg、fin
syn: 表示同步
ack: 表示确认
psh: 表示尽快的将数据送往接收进程
rst: 表示复位连接
urg: 表示紧急指针
fin: 表示发送方完成数据发送
窗口:指定关于发送端能传输的下一段的大小的指令
校验和:校验和包含tcp段头和数据部分,用来校验段头和数据部分的可靠性
紧急:指明段中包含紧急信息,只有当u r g标志置1时紧急指针才有效
选项:指定了公认的段大小,时间戳,选项字段的末端,以及指定了选项字段的边界选项
要看懂tcp解码信息,就必须清楚知道tcp工作原理和tcp报头的相关字段信息。
下面我们就通过科来网络分析系统中的解码信息来认识tcp协议的报头。如下图。
图2 科来网络分析系统tcp解码信息
上图显示了tcp协议中报头中字段的详细信息,这里的解码信息完全和tcp报头结构相吻合,下面我们分别来介绍解码视图中的信息: