TLS/SSL加密通信过程全解

一、

  • 客户端 (curl) 向服务器 (localhost) 发起一个 HTTPS 连接请求。

  • 服务器会将其数字证书发送给客户端。

  • 客户端的操作系统(也就是"你的系统")接收到这个证书后,必须进行验证。它会查看自己本地的"信任证书库"(Trust Store),检查这个证书是不是由一个它已经信任的"证书颁发机构"(CA)签发的。

  • 如果验证通过,连接继续。

  • 如果验证失败(因为签发这个证书的机构不在客户端的信任列表里),curl 就会报错,也就是我们一开始试图解决的"证书错误"。

二、

接下来会发生密钥交换(Key Exchange) ,这是整个 TLS/SSL 握手过程中最核心、最巧妙的部分。目标是让客户端和服务器能够安全地商定一个只有它们俩知道的密钥,用来加密后续的所有通信内容。

这个过程大致如下:

1. 客户端生成一个"秘密"

客户端会生成一个随机的、一次性的对称加密密钥,我们称之为**"会话密钥" (Session Key)**。这个密钥将是接下来所有数据传输的"密码本"。

2. 用服务器的"公开锁"加密这个"秘密"

还记得吗?服务器发过来的证书里包含了一个公钥 (Public Key)。公钥就像一把可以无限复制分发的"开着的锁",任何人都可以用它来加密信息。 客户端现在就用这个公-钥,把刚刚生成的"会话密钥"给锁起来(加密)。

关键点: 被公钥加密的信息,只有拥有与之配对的私钥 (Private Key) 的人才能解开。而这个私钥,全世界只有那台服务器自己持有,从未公开过。

3. 将加密后的"秘密"发送给服务器

客户端把这个被服务器公钥锁住的"会话密钥"发送给服务器。即使这个数据包在网络上被黑客截获了,黑客也没有服务器的私钥,所以完全无法解开它,也就不知道真正的"会话密钥"是什么。

4. 服务器用自己的"私人钥匙"解密

服务器收到这个加密包后,就用自己珍藏的私钥来解密,轻松地得到了客户端发来的那个"会话密钥"。

握手完成,开始安全通信!

至此,客户端和服务器双方都拥有了同一个、不为外人所知的"会话密钥"。这个过程称为TLS/SSL 握手 (Handshake) 成功。

从这一刻起:

  • 客户端 发送给服务器的所有数据(例如 HTTP 请求),都会用这个"会话密钥"进行对称加密

  • 服务器接收到数据后,用同一个"会话密钥"解密,读取内容。

  • 服务器发送给客户端的所有数据(例如网页内容),也用这个"会话密钥"进行加密。

  • 客户端接收到数据后,用同一个"会话密钥"解密。

相关推荐
大数据新鸟1 天前
操作系统之虚拟内存
java·服务器·网络
迷藏4941 天前
**eBPF实战进阶:从零构建网络流量监控与过滤系统**在现代云原生架构中,**网络可观测性**和**安全隔离**已成为
java·网络·python·云原生·架构
zmj3203241 天前
汽车电子内部网络架构图
网络·汽车
汽车仪器仪表相关领域1 天前
NHFID-1000型非甲烷总烃分析仪:技术破局,重构固定污染源监测新体验
java·大数据·网络·人工智能·单元测试·可用性测试·安全性测试
上海云盾-小余1 天前
DDoS 攻击全解析:常见类型识别与分层防御思路
网络协议·tcp/ip·安全·ddos
卤炖阑尾炎1 天前
Python 网络编程实战:从 TCP/UDP 基础到高并发服务器开发
网络·python·tcp/ip
乾元1 天前
《硅基之盾》番外篇二:算力底座的暗战——智算中心 VXLAN/EVPN 架构下的多租户隔离与防御
网络·人工智能·网络安全·架构
不做菜鸟的网工1 天前
H3C 本地 Portal + AAA 认证 模拟配置实验
网络协议
智擎软件测评小祺1 天前
渗透测试报告关键模块拆解
网络·web安全·渗透测试·测试·检测·cma·cnas
W.W.H.1 天前
嵌入式常见的面试题1
linux·网络·经验分享·网络协议·tcp/ip