AJAX(四)—HTTP三次握手四次挥手
一 浏览器渲染流程:
- DNS解析:把域名解析成IP地址
- TCP 建立连接:TCP三次握手
- 发送HTTP请求
- 服务器处理并响应报文
- 浏览器解析并渲染页面
- 断开连接:TCP 结束连接
二 HTTP之TCP三次握手与四次挥手详解:https://www.jianshu.com/p/12790cea57ac
三次握手(Three-way Handshake),是指建立一个 TCP 连接时,需要客户端和服务器总共发送3个包。
- 第一次握手([SYN], Seq = x):客户端发送一个SYN标记的包,Seq初始序列号x,发送完成后客户端进入SYN_SEND状态。
- 第二次握手([SYN,ACK], Seq = y, ACK = x + 1):服务器返回确认包(ACK)应答,同时还要发送一个SYN包回去。ACK = x + 1,表示确认收到(客户端发来的Seq值 + 1),Seq = y, 表示让客户端确认是否能收到。发送完成后服务端进入SYN_RCVD状态。
- 第三次握手([ACK], ACK = y + 1):客户端再次发送确认包(ACK),ACK = y + 1, 表示确认收到服务器的包(服务端发来的Seq值 + 1)。客户端发送完毕后,进入ESTABLISHED状态,服务端接收到这个包,也进入ESTABLISHED状态, TCP握手结束。
TCP连接的断开需要发送四个包,所以称为四次挥手。
- 第一次挥手([FIN], Seq = x):客户端发送一个FIN标记的包,告诉服务器需要关闭连接,表示自己不用发送数据了,但是还可以接收数据。发送完成后,客户端进入FIN_WAIT_1状态。
- 第二次挥手 ([ACK], ACK = x + 1):服务端发送一个ACK的确认包,告诉客户端接收到关闭的请求,但是还没有准备好。发送完成后,服务端进入CLOSE_WAIT状态,客户端收到这个包后,进入FIN_WAIT_2,等待服务器关闭连接。
- 第三次挥手 ([FIN], Seq = y):服务端准备好关闭连接时,发送FIN标记的包,告诉客户端准备关闭了。发送完成后,服务端进入LAST_ACK状态,等待客户端确认。
- 第四次挥手 ([ACK], ACK = y + 1):客户端接收到服务端的关闭请求,再发送ACK标记的确认包,进入TIME_WAIT状态,等待服务端可能请求重传的ACK包。服务端接收到ACK包后,关闭连接,进入CLOSED状态。客户端在等待固定时间(两个最大段生命周期)后,没有接收到服务的ACK包,认为服务器已关闭连接,自己也关闭连接,进入CLOSED状态。
三 HTTP三次握手与四次挥手动态图:https://baijiahao.baidu.com/s?id=1654225744653405133&wfr=spider&for=pc
序号(sequence number):seq序号,占32位,用来标识从TCP源端向目的端发送的字节流,发送自己的数据。
确认号(acknowledgement number):ack序号,占32位,只有ACK标志位为1时,确认序号字段才有效,ack=seq+1。(发送接收到的对方的数据)
标志位(Flags):共6个,即URG、ACK、PSH、RST、SYN、FIN等。具体含义如下:
- URG:紧急指针(urgent pointer)有效。
- ACK:确认序号有效。(为了与确认号ack区分开,我们用大写表示),用于确定收到了请求。
- PSH:接收方应该尽快将这个报文交给应用层。
- RST:重置连接。
- SYN:用于建立连接。同步序列编号(Synchronize Sequence Numbers)
- FIN:释放一个连接。
三 HTTP中GET与POST区别:GET与POST理解
- GET参数通过URL传递,POST放在Request body中;所以GET比POST更不安全,因为参数直接暴露在URL上,所以不能用来传递敏感信息。
- GET请求只能进行url编码,而POST支持多种编码方式。且GET传递参数长度是有限制的,而POST没有。对参数的数据类型,GET只接受ASCII字符,而POST没有限制。
- GET请求参数会被完整保留在浏览器历史记录里,而POST中的参数不会被保留。
- 重要区别:GET产生一个TCP数据包;POST产生两个TCP数据包。对于GET方式的请求,浏览器会把http header和data一并发送出去,服务器响应200(返回数据);而对于POST,浏览器先发送header,服务器响应100 continue,浏览器再发送data,服务器响应200 ok(返回数据)