前端学习23 http和https
1.概念
HTTP:超文本传输协议(Hyper Text Transfer Protocol)是一种详细规定了浏览器和万维网服务器之间互相通信的规则,通过因特网传送万维网文档的数据传送协议。
HTTPS:超文本传输安全协议(Hypertext Transfer Protocol Secure,简称:HTTPS)是一种通过计算机网络进行安全通信的传输协议。HTTPS经由 HTTP 进行通信,利用 SSL/TLS 来加密数据包。HTTPS 的主要目的是提供对网站服务器的身份认证,保护交换数据的隐私与完整性。
2.http和https区别
- HTTP是明文传输,连接很简单,是无状态的。https协议是有SSL+HTTP协议构建的可进行加密传输、身份证的网络协议,比HTTP协议安全。
- HTTP对搜索引擎更友好,利于SEO;谷歌、百度优先索引HTTPS网页。
- 使用不同的连接方式,端口也不同,HTTPS标准端口443,HTTP标准端口80。
- HTTPS协议需要CA证书,费用较高,而HTTP协议不需要。
3.HTTPS 握手过程
- 客户端发起 HTTPS 请求,发送客户端生成的随机数1和支持的加密算法列表;
- 服务端返回证书、服务端生成的随机数2、选择的加密方法给客户端;
- 客户端对证书进行合法性验证,验证通过后再生成一个随机数3,并使用数字证书中的公钥,加密这个随机数,然后发给服务器。并且还会提供一个前面所有内容的 hash 的值,用来供服务器检验。
- 服务器使用自己的私钥,来解密客户端发送过来的随机数3。并提供前面所有内容的 hash 值来供客户端检验。
- 三次握手此时已经完成,之后客户端和服务端都会根据这三个随机数,生成一个随机对称密钥,之后的数据都通过随机对称密钥进行加密传输。
4.TCP的三次握手、四次挥手
4.1 三次握手
关键标志位
- SYN,简写为S,同步标志位,用于建立会话请求,同步序列号;
- ACK,简写为.,确认标志位,确认已接受的数据包;
- FIN,简写为F,完成标志位,表示传输完毕,将要关闭连接;
若SYN=1,ACK=0,表示是来自发送方的一个“连接请求”;
若SYN=1,ACK=1,表示接收方“同意接受连接请求”。
第一次握手:客户端主动打开连接,将TCP报文标志位SYN置为1,并随机产生一个序号值seq=x(SYN=1,ACK=0,seq=x,请求连接),发送数据包给服务端。发送完毕进入SYN-SENT状态;
第二次握手:服务端接收到标志位为SYN=1,ACK=0的数据包,得知客户端请求建立连接。服务端将标志位置作:SYN=1,ACK=1,ack=x+1,并随机产生序号值seq=y;发送数据包给客户端,同意建立连接。进入SYN-RCVD状态。
第三次握手:客户端得到了服务端的确认。检查ACK是否为1,ack是否为x+1。若是的话,则ACK=1,ack=y+1。服务端再检查,ACK是否为1,ack是否为y+1。若正确则建立好连接通道。
第三次握手保证了B的资源不会被浪费(如果A一直不发送数据)。
4.2 四次挥手
第一次挥手: 客户端想释放连接。使FIN=1,表示请求释放连接,随机产生seq=x;发送给客户端,并进入FIN-WAIT-1阶段(半关闭状态,停止客户端向服务器端上发送数据)。但实际上,客户端还能向服务器端发送ACK确认报文。
第二次挥手: 服务器端接收到客户端想释放连接的请求。使ACK=1,ack=x+1,并随机产生seq=y。发送给客户端,表示“接收到了客户端的想释放连接的请求”。服务器端进入CLOSE-WAIT阶段。
客户端接收到报文,进入FIN-WAIT-2阶段。
前两次握手:客户端让服务器端知道:我想释放连接;服务器端让客户端知道:我知道了你想释放连接。于是可以确认关闭客户端到服务器端的连接,完成了一个方向上连接的释放!
第三次挥手: 在第二次挥手发送报文给客户端时,服务器端进入了CLOSE-WAIT阶段。当CLOSE-WAIT结束后, 服务器端做好了释放“服务器端到客户端方向”连接的准备。于是发送报文,使FIN=1,ACK=1,表示准备好释放连接。ack=x+1,seq=z;随后,服务器端进入LAST-ACK阶段。停止服务器端到客户端发送数据,但能接受来自客户端的数据。
第四次挥手: 客户端发送报文:ACK=1表示接收到了“服务器准备好释放连接".ack=z+1,seq=w;。
因为TCP是全双工模式,两个方向都可以进行通信,所以需要四次挥手来关闭两个方向上的连接。