了解HTTPS的三次握手

HTTPS也有三次握手,不同于HTTP的三次握手

第一次握手

客户端将协议版本号、生成一个随机字符串A、客户端支持的加密算法a~d,向服务器发送请求。

第二次握手

服务器收到请求后,将字符串A存储到本地,并从客户端支持的加密算法中选择一个算法c、并给出一个证书、同时也生成一个随机字符串B,响应到客户端。

第三次握手

客户端收到响应后,根据CA机构提供的整数公钥来解密证书中的签名,确定证书的真实有效性,并校验一些其他信息(例如请求的域名是否与证书中一致),所有校验通过后,将从证书中得到的公钥public_key,并新生成一个随机字符串C,并使用证书中的公钥加密形成secret_key值,发送到服务器。

服务器后续

服务器收到加密后的secret_key值后,用自己的私钥进行解密验证,得到字符串C。三次握手至此完成。

后续请求

三次握手成功后,客户端和服务器后续的每次请求,都将使用前三次的随机字符串A、B、C,使用加密算法c,生成一个对称秘钥symmetric_key,来进行加密解密

相关推荐
耕耘虫1 小时前
解决 .Net 6.0 项目发布到IIS报错:HTTP Error 500.30
网络·网络协议·http·iis·net·静态文件·.net 6.0
前端切图仔0013 小时前
WebSocket 技术详解
前端·网络·websocket·网络协议
7ACE4 小时前
Wireshark TS | 异常 ACK 数据包处理
网络协议·tcp/ip·wireshark
小白iP代理6 小时前
随机IP的重要性:解锁网络世界的无限可能
网络·网络协议·tcp/ip·网络安全
2501_915106327 小时前
iOS 设备应用管理实践分享
websocket·网络协议·tcp/ip·http·网络安全·https·udp
胡狼FPGA7 小时前
手撕网络协议,实现100G网络UDP通信
网络·网络协议·udp
2501_915106328 小时前
flutter 真机调试 ios
websocket·网络协议·tcp/ip·http·网络安全·https·udp
JA+11 小时前
在断网的时候,websocket 一直在CLOSING 状态
网络·websocket·网络协议
格格Code11 小时前
UDP概念特点+编程流程
网络·网络协议·udp
00后程序员张11 小时前
Flutter的自动化测试 python flutter编程
websocket·网络协议·tcp/ip·http·网络安全·https·udp