12、HTTPS的工作原理(HTTPS建立连接的过程)【中高频】

SSL/TLS 协议基本流程:

  1. 客户端向服务器 索要 并 验证 服务器的公钥。
  2. 双方协商生产「会话秘钥」。
  3. 双方采用「会话秘钥」进行加密通信。

前两步也就是 SSL/TLS 的建立过程,也就是 TLS 握手阶段。 TLS 握手阶段涉及四次通信,使用不同的密钥交换算法,TLS 握手流程也会不一样的,现在常用的密钥交换算法有两种:RSA 算法 (opens new window)和 ECDHE 算法。

TLS 协议建立的详细流程:

  1. 客户端 发起第一次握手

首先,由客户端向服务器发起 加密通信请求,包含以下信息:

(1)客户端支持的 TLS 协议版本,如 TLS 1.2 版本。

(2)客户端支持的密码套件列表,如 RSA 加密算法。

(3)客户端生产的随机数(Client Random)

  1. 服务器 发起第二次握手

服务器收到客户端请求后,向客户端发出响应,包含以下信息:

(1)确认 TLS 协议版本(如果浏览器不支持,则关闭加密通信)和 密码套件列表

(3)服务器生产的随机数(Server Random)

(4)服务器的数字证书(里面有 服务器公钥,它加密的报文只有 服务器私钥 能解)

  1. 客户端 发起第三次握手

客户端收到服务器的回应之后,首先做这两件事:

  • 通过(浏览器或者操作系统中的 )CA 公钥,验证 服务器数字证书的真实性。
  • 从数字证书中取出 服务器的公钥,加密报文
  • 三个随机数(Client Random、Server Random、pre-master key)配合之前协商的加密算法 生成会话秘钥

报文中包含以下信息:

(1)客户端生产的随机数(pre-master key),并用服务器公钥加密(第三个随机数,服务器也继续用这个)

(2)通知服务器 加密通信算法 已改为 会话秘钥

(3)返回所有握手数据的摘要,并结束握手

  1. 服务器发起 第四次握手

服务器收到客户端消息后,

  • 用 服务器私钥 解密,取出随机数
  • 利用三个随机数和协商的加密算法,生成会话密钥

报文中包含以下信息:

(1)通知服务器 加密通信算法 已改为 会话秘钥

(2)返回所有握手数据的摘要,并结束握手

至此,整个 TLS 的握手阶段全部结束。接下来,客户端与服务器 使用普通的 HTTP 协议,只不过用「会话秘钥」加密内容。

相关推荐
2501_916008892 分钟前
全面介绍Fiddler、Wireshark、HttpWatch、SmartSniff和firebug抓包工具功能与使用
android·ios·小程序·https·uni-app·iphone·webview
暖馒6 分钟前
Modbus应用层协议的深度剖析
网络·网络协议·c#·wpf·智能硬件
开源技术2 小时前
DNS详解——域名是如何解析的
http
吠品6 小时前
命令行揭示SSL证书真相
https·github·ssl
三水不滴8 小时前
有 HTTP 了为什么还要有 RPC?
经验分享·笔记·网络协议·计算机网络·http·rpc
宝塔面板10 小时前
AllinSSL 一站式搞定 SSL 自动续期:永久免费,开源可自托管
网络·网络协议·ssl
csdn今天倒闭了吗10 小时前
飞牛lucky配置ipv6 ddns+ssl+反向代理
网络·网络协议·ssl
JavinLu10 小时前
ios 配置了代理且使用 chls.pro/ssl 下载不了证书,无法弹出下载证书的提示问题
网络协议·ios·ssl
菜鸟特工00710 小时前
javax.net.ssl.SSLPeerUnverifiedException 异常如何处理
网络协议·.net·ssl
天荒地老笑话么10 小时前
静态 IP 规划:掩码/网关/DNS 的正确组合
网络·网络协议·tcp/ip·网络安全