TCP协议学习之三次握手

本文通过使用Wireshark抓取网络包的方式详细解析了TCP三次握手的过程。包括客户端如何发起连接请求,服务器如何响应以及最终如何建立连接。展示了每个握手阶段的数据包特征及标志位的变化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

其实一直都想把知识点复习下,这次不能再拖延了

一.抓包工具是Wireshark

基本的操作就不介绍了,主要就是选择当前网络,然后Start.
在浏览器打开主页zckongbai.farbox.com,然后在Wireshark中过滤当前的IP:

过滤ip

二.握手详情

网络层次划分如下,三次握手是传输层的TCP协议和应用层之间的交互

协议模型图
所有我们在抓包分析的时候主要关注的就是传输层- Transmission Control Protocol ,如上图标注所示.
先看看TCP报文段格式:

tcp报文
对应Wireshark抓包的数据
这里写图片描述

比较重要的:
Sequence number – 序号
Acknowledgment number – 确认号
Flags – 标志位
— Acknowledgment 确认位
— Push 急迫位
— Reset 重置位
— Syn 同步位
— Fin 终止位

好了, 正式开始分析握手吧.

因为我们打开一个网站的时候,可能会同时建立多个请求,所以在Wireshark里面会抓到很多个请求,这个时候,我们选取一个,右击 Conversation Filter > Tcp 这样就过滤出这次完整的TCP请求流程

过滤一次TCP

1.第一次握手

客户端发送syn包(syn=j)到服务器,并进入SYN_SEND状态,等待服务器确认:
localhost Seq=0 -> 博客地址

从标志位可以看到,同步位Syn有值,在做请求[SYN]: Syn同步位为1

第一次握手

2.第二次握手

服务器收到syn包,必须确认客户的SYN(ack=j+1),同时自己也发送一个SYN包(syn=k),即SYN+ACK包,此时服务器进入SYN_RECV状态:
博客地址 Seq=0 Ack=1 -> localhost

从标志位看出,确认位、同步位有值,在做应答(SYN+ACK):Syn 同步位为 1 、Acknowledgment 确认位为 1

第二次握手

3.第三次握手

客户端收到服务器的SYN+ACK包,向服务器发送确认包ACK(ack=k+1),此包发送完毕,客户端和服务器进入ESTABLISHED状态,完成三次握手:
localhost Seq=1 Ack=1 -> 博客地址 (注: Seq=Seq+1)

从标志位看出,只有确认位有值,在做再次确认(SYN): Acknowledgment确认位为1

这里写图片描述

到此完成三次握手,客户端与服务器开始传送数据.
完整的步骤就是:
请求(SYN) -> 应答(SYN+ACK) -> 再次确认(SYN)

完整流程图

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值