HTTPS详解:原理 + 加解密过程 + 面试问答

一、HTTP 与 HTTPS 的区别

项目 HTTP HTTPS
全称 HyperText Transfer Protocol HyperText Transfer Protocol Secure
端口 80 443
协议层 应用层 应用层 + TLS(安全层)
加密方式 明文传输 加密传输(TLS)
安全性 易被劫持、中间人攻击 可加密、防篡改、防伪装
是否需证书 是(由 CA 机构颁发)

二、HTTPS 的核心安全保障

HTTPS 基于 TLS(或旧版 SSL)实现以下三个目标:

  1. 机密性(防监听):使用对称加密加密数据内容
  2. 身份认证(防伪装):通过数字证书验证服务器身份
  3. 完整性校验(防篡改):使用摘要算法保证数据未被修改

三、HTTPS 加密通信原理(TLS 握手过程)

混合加密机制:

加密方式 使用目的 特点
非对称加密 握手阶段传输密钥 安全但慢
对称加密 正文传输 快但需安全传递密钥
摘要 + MAC 校验完整性 防止数据被篡改

TLS 1.2 握手步骤:

Client Server 1. Client Hello(支持算法、随机数) 2. Server Hello(选定算法、证书、随机数) 3. 验证证书 → 生成密钥 → 加密发送 4. 解密密钥 → 会话密钥建立 5. 用对称密钥加密通信开始 Client Server


四、数字证书与身份认证

数字证书包含:

  • 公钥
  • 服务器域名
  • 颁发机构(CA)
  • 有效期
  • 签名算法(SHA256)

验证方式:

客户端浏览器内置 根证书列表,通过链式验证服务器的证书是否被信任。


五、TLS 1.3 对比 TLS 1.2

特性 TLS 1.2 TLS 1.3
握手轮次 至少 2 次 RTT 最快 1 次 RTT(支持 0-RTT)
加密套件 多(含部分弱算法) 默认强加密(去除 RSA 握手)
会话恢复 使用 Session ID/Ticket 使用 PSK
前向保密 可选 默认启用

六、HTTPS 常见问题总结

1. HTTPS 为什么比 HTTP 安全?

答: HTTPS 使用 TLS 实现加密通信、防监听、防篡改和身份认证,相比 HTTP 明文传输更安全。


2. HTTPS 使用哪些加密算法?

类型 说明 示例算法
非对称加密 握手阶段传输密钥 RSA、ECDHE
对称加密 加密通信内容 AES、ChaCha20
摘要算法 校验完整性 SHA-256、HMAC

3. HTTPS 全程使用非对称加密吗?

答: 否。

握手阶段使用非对称加密交换对称密钥,之后的通信使用对称加密(更高效)。


4. 数字证书是什么?客户端如何验证?

答: 证书由 CA 签发,包含服务器公钥、域名等信息。客户端通过浏览器预置的根证书验证其合法性(链式信任模型)。


5. TLS 握手过程简述?

答: 客户端发送 Hello → 获取服务器证书 → 验证后生成对称密钥 → 使用公钥加密密钥传输 → 建立安全通道。


6. 中间人攻击是什么?HTTPS 如何防止?

答: 中间人伪装成服务端窃听数据。HTTPS 使用证书认证 + 加密通信,确保客户端只能与真正的服务器通信,防止中间人。


7. TLS 1.2 vs TLS 1.3 的主要区别?

  • TLS 1.3 性能更优,握手更快(支持 0-RTT)
  • 移除不安全算法,默认启用前向保密
  • 加密元数据更强,防止探测

七、总结

特性 HTTPS 优势
保密性 数据加密,防止监听
身份认证 数字证书,防止伪造
完整性 摘要校验,防止数据被篡改
性能(TLS 1.3) 握手更快,资源更节省
应用场景 登录、支付、传输隐私数据的所有 Web 应用场景
相关推荐
没有bug.的程序员12 分钟前
电商系统分布式架构实战:从单体到微服务的演进之路
java·分布式·微服务·云原生·架构·监控体系·指标采集
Query*22 分钟前
Java 设计模式——代理模式:从静态代理到 Spring AOP 最优实现
java·设计模式·代理模式
梵得儿SHI23 分钟前
Java 反射机制深度解析:从对象创建到私有成员操作
java·开发语言·class对象·java反射机制·操作类成员·三大典型·反射的核心api
JAVA学习通27 分钟前
Spring AI 核心概念
java·人工智能·spring·springai
望获linux29 分钟前
【实时Linux实战系列】实时 Linux 在边缘计算网关中的应用
java·linux·服务器·前端·数据库·操作系统
绝无仅有37 分钟前
面试真实经历某商银行大厂数据库MYSQL问题和答案总结(二)
后端·面试·github
绝无仅有39 分钟前
通过编写修复脚本修复 Docker 启动失败(二)
后端·面试·github
..Cherry..41 分钟前
【java】jvm
java·开发语言·jvm
老K的Java兵器库1 小时前
并发集合踩坑现场:ConcurrentHashMap size() 阻塞、HashSet 并发 add 丢数据、Queue 伪共享
java·后端·spring
歪歪1001 小时前
使用 Wireshark 进行 HTTP、MQTT、WebSocket 抓包的详细教程
网络·websocket·测试工具·http·wireshark