HTTPS 是怎么工作的

HTTPS = HTTP + TLS。它做的事很简单:先建立安全通道,再在通道里传 HTTP 数据。

1、先建 TCP 连接(三次握手)

客户端发 SYN → 服务器回 SYN+ACK → 客户端回 ACK。此时连接建立,但还没加密。

2、开始 TLS 握手:协商"怎么加密"

客户端发 ClientHello:支持的 TLS 版本、加密套件、随机数等。

服务器回 ServerHello:选定版本/套件,并把证书发给客户端(包含服务器公钥)。

3、证书校验:确认你连的真的是它

客户端用系统/浏览器内置的 CA 根证书链去验证:

证书是否被可信机构签发、是否过期、域名是否匹配、是否被吊销等。

通过后,才能继续,否则浏览器会提示不安全。

4、密钥交换:生成"会话密钥"

关键点:非对称加密(公钥/私钥)主要用来"安全地协商密钥",不适合大量数据传输。

客户端与服务器通过密钥交换算法(如 ECDHE)协商出同一把会话密钥(对称密钥)。

会话密钥只在本次连接里用,速度快,安全性高。

5、切换到加密通道(Change Cipher Spec)

双方确认后续都用会话密钥进行加密/解密,并完成握手。

6、加密传输数据

接下来传的就是加密后的 HTTP 请求/响应(Encrypted Data)。

同时配合完整性校验(防篡改)与身份验证(防冒充)。

一句话总结

TCP 负责"连上";TLS 负责"验证身份 + 协商密钥 + 加密传输"。

非对称:用来握手与身份认证;对称:用来高效加密传数据。

相关推荐
extrao12 小时前
🚀 Kea DHCP4 自动分配系统完整搭建
网络协议
喵个咪15 小时前
Go-Wind HTTP 服务器从入门到精通
后端·http·go
不做菜鸟的网工2 天前
BGP特性
网络协议
AlfredZhao3 天前
生产环境里,为什么不建议把普通端口直接暴露到公网?
linux·https·443·80
明月_清风4 天前
开发者网络概念全扫盲:一篇搞定
后端·网络协议
刘马想放假5 天前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
王二端茶倒水6 天前
一套可落地的无线运营方案,不能只管 AP,还要管用户、计费和运维
网络协议
162723816086 天前
EtherCAT 分布式时钟(DC)原理与配置实战:把多轴真正"对齐到同一时刻"
网络协议
王二端茶倒水6 天前
宽带无线项目,怎么从一次性交付变成长期运营收入?
网络协议
Goodbye6 天前
大模型无状态架构:从 HTTP 协议到 Harness AI 工程的深度解析
http