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 负责"验证身份 + 协商密钥 + 加密传输"。

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

相关推荐
阿捏利19 小时前
详解网络协议(十六)UDP协议
网络·网络协议·udp
taxunjishu20 小时前
AGV 与伺服协同控制Profinet 转 Modbus TCP塔讯智能网关仓储场景应用实践
网络·网络协议
情绪雪20 小时前
IP 协议基本原理
网络·网络协议·tcp/ip
Lucas_coding21 小时前
【语音相关ASR】OpenAI 兼容 Qwen_ASR 接口调用实战:SDK 与 HTTP 方式详解
网络·网络协议·http
不会写DN1 天前
如何设计应用层 ACK 来补充 TCP 的不足?
开发语言·网络·数据库·网络协议·tcp/ip·golang
snow@li1 天前
协议:应用层开发都会涉及哪些协议 / 详细整理 / http、ws、https、wss
网络协议·http·https
椰猫子1 天前
Javaweb(Http、Maven)
网络·网络协议·http
小心我捶你啊1 天前
SOCKS5与HTTP代理的差异与应用场景抉择
网络·网络协议·http
z10_141 天前
动态住宅 IP 能做什么?[动态住宅 IP流量包] 免费测试!
服务器·网络协议·tcp/ip
tang777891 天前
小红书平台用什么代理IP?数据采集IP封禁解决方法
数据库·爬虫·python·网络协议·ip