当前位置: 首页 > news >正文

计算机网络 TLS握手中三个随机数详解

在 TLS 握手过程中,三个随机数是生成最终会话密钥的核心要素,它们共同保障通信的前向保密性会话唯一性。以下是详细解析:


三个随机数的定义与作用

随机数来源长度核心作用
Client Random客户端生成32字节包含客户端支持的TLS版本、时间戳和随机字节,防止重放攻击。
Server Random服务器生成32字节包含服务器选定的TLS版本、时间戳和随机字节,确保会话独立性。
PreMaster Secret客户端生成48字节核心密钥材料(如RSA加密传输或DH交换生成),用于推导主密钥(Master Secret)。

密钥生成流程

三方共同参与生成最终密钥:

  1. 输入
    Master Secret = PRF(PreMaster Secret, "master secret", Client Random + Server Random)
    PRF = 伪随机函数,TLS 1.2+默认用SHA-256)
  2. 最终会话密钥
    会话密钥 = PRF(Master Secret, "key expansion", Client Random + Server Random)
    (包括对称加密密钥、MAC密钥、初始化向量等)

为什么需要三个随机数?

  1. 防御重放攻击
    • 若缺少 Client RandomServer Random,攻击者可重放旧握手数据,服务器无法区分新旧会话。
  2. 保障前向保密
    • 即使服务器私钥泄露(如RSA密钥交换),攻击者也无法解密历史会话——因为 PreMaster Secret 是临时生成的,且依赖随机数生成主密钥。
  3. 会话唯一性
    • 三个随机数确保每次会话的密钥唯一。即使同一客户端反复连接,密钥也不同(避免关联攻击)。

能否去掉某个随机数?

场景分析
随机数能否去掉?后果
Client Random❌ 不可服务器无法验证客户端 freshness,重放攻击风险激增。
Server Random❌ 不可客户端无法验证服务器 freshness,中间人可伪造服务器响应。
PreMaster Secret❌ 不可无核心密钥材料,无法生成会话密钥(TLS 1.3已通过DH直接共享替代此步骤)。

特殊说明(TLS 1.3)

  • PreMaster Secret(EC)DHE共享密钥 替代,但 Client RandomServer Random 仍保留,用于密钥推导和防重放。
  • TLS 1.3中密钥计算:
    Master Secret = HKDF-Extract(Shared Secret, Client Random + Server Random)

各版本中的演进

  • TLS 1.0–1.2
    显式传输 PreMaster Secret(RSA加密)或通过DH交换生成。
  • TLS 1.3
    • 移除 PreMaster Secret 概念,直接由(EC)DHE交换生成共享密钥。
    • Client Random/Server Random 仍参与密钥派生(HKDF)。

安全意义

  • 随机性质量要求
    三个随机数必须由密码学安全的随机数生成器(CSPRNG)产生。
    (如2012年Android随机数漏洞导致私钥泄露)
  • 长度不可缩减
    32字节长度可抵御暴力破解(2²⁵⁶搜索空间)。

总结

关键点说明
三个随机数缺一不可共同实现会话唯一性、前向保密性和身份验证。
TLS 1.3的优化移除 PreMaster Secret 的显式传输,但随机数参与密钥派生的核心逻辑不变。
实践建议确保系统熵源充足(如Linux的/dev/urandom),避免随机数重复。

可通过抓包工具(如Wireshark)查看 Client HelloServer Hello 中的随机数字段(各32字节),而 PreMaster Secret 在RSA密钥交换中可见为加密的48字节数据。

http://www.xdnf.cn/news/1352071.html

相关文章:

  • 【Golang】有关垃圾收集器的笔记
  • 语义通信高斯信道仿真代码
  • GaussDB 数据库架构师修炼(十八) SQL引擎-计划管理-SQL PATCH
  • Base64编码、AES加密、RSA加密、MD5加密
  • RAG Embeddings 向量数据库
  • 使用Ollama部署自己的本地模型
  • 疯狂星期四文案网第48天运营日记
  • 12 SQL进阶-锁(8.20)
  • Python语法速成课程(二)
  • 科技赋能,宁夏农业绘就塞上新“丰”景
  • 进程的概念:进程调度算法
  • 【GPT入门】第57课 详解 LLamaFactory 与 XTuner 实现大模型多卡分布式训练的方案与实践
  • rust语言 (1.88) egui (0.32.1) 学习笔记(逐行注释)(七) 鼠标在控件上悬浮时的提示
  • linux中文本文件操作之grep命令
  • 【软件设计模式】策略模式
  • MySQL:事务管理
  • Intel RealSense D435 深度相机详解
  • Java 学习笔记(基础篇8)
  • Linux总线设备驱动模型深度理解
  • Vue3 学习教程,从入门到精通,基于 Vue 3 + Element Plus + ECharts + JavaScript的51购商城项目(45)
  • imx6ull-驱动开发篇37——Linux MISC 驱动实验
  • 大模型四种常见安全问题与攻击案例
  • MySQL数据库管理与索引优化全攻略
  • 力扣(全排列)
  • 使用 PSRP 通过 SSH 建立 WinRM 隧道
  • Linux-常用文件IO函数
  • jQuery 知识点复习总览
  • (nice!!!)(LeetCode 面试经典 150 题) 173. 二叉搜索树迭代器 (栈)
  • 55 C++ 现代C++编程艺术4-元编程
  • 数据结构与算法-字符串、数组和广义表(String Array List)