TCP/IP三次握手四次挥手简单介绍

三次握手

第一次握手—客户端给服务端发送一个连接请求信息,发送SYN报文,进入SYN_SENT状态

第二次握手—服务端收到客户端发送的连接请求后,给客户端发送一个ACK包和一个SYN包,进入SYN_RECE状态

第三次握手—客户端收到服务端发给的ACK包和SYN包之后,向服务端发送一个ACK包,发送完毕后,服务端和客户端均进入ESTABLISHED状态,至此,服务端开始给客户端发送数据

四次挥手

第一次挥手—客户端发送链接释放报文,并且停止发放数据。进入结束等待1阶段

第二次挥手—服务端收到客户端发送的链接释放报文,给客户端发送一个确认报文,进入关闭等待状态

第三次挥手—客户端收到服务端发送的确认报文,进入终止等待状态,等待服务端发送链接释放报文

第四次挥手—服务端发送完所有的数据之后, 向客户端发送链接释放报文并断开连接,客户端收到服务端发送的释放报文之后也断开连接,至此,四次挥手结束

举个例子来说明一下:
小明给小红打电话,
小明:喂?可以听见吗?(一次握手)
小红:嗯,我可以听见,你呢?(二次握手)
小明:我也可以,开始说话。(三次握手)
小明已经把要说的话说完了,之后
小明:我已经说完了(一次挥手)
小红:好,我也快说完了,继续说(二次挥手)
小明:等待小红说完她要说的话(二次挥手)
小红:我也说完了,挂了电话(三次挥手)
小明:等小红挂了电话之后也把电话挂了(四次挥手)

三次握手有缺陷,可以被黑客利用,进行拒绝服务攻击

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
TCP/IP协议中的三次握手是为了在客户端和服务端建立一个安全可靠的连接。在第三次握手时,客户端能够发出第三次握手报文,表示已经接收到来自服务端的第二次握手报文,从而确认连接的建立。此时,服务端的状态会切换为ESTABLISHED,可以开始传输数据了。\[1\] 三次握手的过程如下: 1. 客户端发送一个连接请求报文给服务端,表示想要建立连接。 2. 服务端接收到请求后,发送一个确认报文给客户端,表示已经收到请求。 3. 客户端接收到确认报文后,再次向服务端发送一个确认报文,表示已经收到服务端的确认。 至于为什么不进行四次握手,实际上是可以的,即在服务端收到客户端的第一次连接请求后,可以将ACK和SYN分两次发送给客户端。但这样做会浪费资源,因为一次能完成的事情为什么要分为两次呢?所以,TCP/IP协议采用了三次握手的机制来建立连接。\[2\]\[3\] #### 引用[.reference_title] - *1* [TCP/IP协议、三次握手四次挥手详解](https://blog.csdn.net/Q0717168/article/details/111933810)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [TCP三次握手四次挥手(详细+通俗)](https://blog.csdn.net/m0_38089031/article/details/108567936)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值