客户端发送 SYN 服务端发送 SYN和ACK 客户端发送 ACK

名词解释

参考文章:

https://baike.baidu.com/item/Syn

https://baike.baidu.com/item/ACK

SYN

SYN:同步序列编号(Synchronize Sequence Numbers)。是TCP/IP建立连接时使用的握手信号。在客户机和服务器之间建立正常的TCP网络连接时,客户机首先发出一个SYN消息,服务器使用SYN+ACK应答表示接收到了这个消息,最后客户机再以ACK消息响应。这样在客户机和服务器之间才能建立起可靠的TCP连接,数据才可以在客户机和服务器之间传递。

TCP连接的第一个包,非常小的一种数据包。SYN 攻击包括大量此类的包,由于这些包看上去来自实际不存在的站点,因此无法有效进行处理。每个机器的欺骗包都要花几秒钟进行尝试方可放弃提供正常响应。

ACK

ACK(Acknowledge character)即是确认字符,在数据通信中,接收站发给发送站的一种传输类的一种传输类控制字符。表示发来的数据已确认接收无误。

在TCP/IP协议中,如果接收方成功的接收到数据,那么会回复一个ACK数据。通常ACK信号有自己固定的格式,长度大小。由接收方回复给发送方。

TCP 报文格式

原文地址: HTTP 通信 —— 三次握手和四次挥手

TCP和IP协议分别是传输层网络层协议,主要解决数据如何在网络中传输;HTTP是应用层协议,主要解决如何包装数据,用以封装 HTTP 文本信息。

因为HTTP是在TCP/IP之上的应用层协议,所以关于HTTP的三次握手,其实就是使用三次TCP握手确认建立一个HTTP连接。

先看TCP报文格式:

https://user-images.githubusercontent.com/20310190/63263267-b05b7480-c2ba-11e9-991f-4763e071f386.png#id=hlU40&originHeight=510&originWidth=1598&originalType=binary&ratio=1&status=done&style=none

上图中有几个字段需要重点介绍下: