news 2026/2/22 11:50:02

AES-GCM加密全流程解析

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
AES-GCM加密全流程解析

核心架构:GCM =CTR流加密+GHASH认证
安全目标:机密性 + 完整性 + 抗重放(AEAD模式)


🔄完整加密流程(以AES-128为例)

步骤1:初始化参数准备
参数要求示例值
密钥(K)128/192/256位0x2b7e151628aed2a6abf71588...
Nonce(IV)唯一值(推荐12字节随机)0xcafebabefacedbad(12字节)
附加数据(AAD)需认证的明文头(可空)HTTP协议头
明文(P)待加密数据"SecretMessage" (14字节)

⚠️致命规范:同一密钥下Nonce绝对不可重复


步骤2:生成认证子密钥H

  • 操作:用密钥K加密16字节的全零块
  • 作用:作为GHASH乘法的固定密钥(Galois域乘数)

步骤3:构造初始计数器(J₀)
  • Case 1:Nonce为12字节(推荐)

    示例:0xcafebabefacedbad00000001

  • Case 2:Nonce非12字节

  • IV = 96位(12字节):直接作为前128位计数器块的高96位,低32位置0:J₀ = IV || 0³¹1(即IV后补4字节00 00 00 01)。
  • IV ≠ 96位:通过GHASH函数计算J₀ = GHASH_H(IV || 0^{s} || len(IV)_64),其中s = 128 - (len(IV) mod 128) - 128len(IV)_64是IV长度的64位表示。

步骤4:CTR模式加密明文
# 伪代码实现 def CTR_Encrypt(K, J0, plaintext): ctr = J0 # 初始计数器 ciphertext = b'' for i in range(0, len(plaintext), 16): ctr = increment(ctr) # 末32位+1 (Big-Endian) keystream = AES_Encrypt(K, ctr) block = plaintext[i:i+16] # 当前明文块 ciphertext += xor(block, keystream[:len(block)]) return ciphertext
  • 特性
    • 无填充要求(任意长度数据)
    • 支持并行计算(硬件加速关键)

✅ **步骤5:GHASH认证计算

输入数据序列

  • 数据块拆分

  • 迭代GHASH计算

    \begin{align*} Y_0 &= 0^{128} \\ Y_i &= (Y_{i-1} \oplus X_i) \cdot H \quad \text{(GF(2^{128})乘法)} \\ \text{结果} &= Y_m \end{align*}
  • 解析:输入拼接X = AAD || 0^v || C || 0^u || len(AAD)_64 || len(C)_64
    • len()_64:AAD和C长度的64位大端表示。
    • u:填充至密文长度为128的倍数(u = 128 - (len(C) mod 128))。
    • v:填充至AAD长度为128的倍数(v = 128 - (len(AAD) mod 128))。
    • 分块处理:将X分成128位块X_1, X_2, ..., X_n
    • 迭代计算
      Y_0 = 0¹²⁸ Y_i = (Y_{i-1} \oplus X_i) \cdot H \quad \text{(在GF(2¹²⁸)域)}
      • 最终输出S = Y_n(GHASH结果)。
  • 加密初始计数器块T' = CIPH_K(J₀)

  • 生成标签T = MSB_t(S \oplus T')(取结果的前t位,通常t=128)。

🔬GF(2¹²⁸)乘法优化
硬件通过CLMUL指令单周期完成(Intel/AMD CPU)


步骤6:生成认证标签(Tag)

  • 截断输出(可选但需≥96位):

📦最终输出

组件长度要求示例
密文(C)同明文长度0x3AD77BB40D7A3660...
认证标签(T)128位(不可截断)0x5BC94FBC3221A5DB94FAE95...

🔧解密验证流程

  1. 用相同(K, Nonce)重新计算CTR密钥流
  2. 解密获得明文:P' = C ⊕ keystream
  3. 认证验证
    • 用相同参数重算GHASH → 得预期标签T_expected
    • 比对接收标签T_received == T_expected
    • 不等则立即丢弃数据(防篡改)

安全关键点

  1. Nonce重用灾难
    • 若两次加密使用相同(K, Nonce)H密钥泄露→ 完全破解
      # 攻击示例(理论) T1 ⊕ T2 = (AES(K,J0)⊕GHASH1) ⊕ (AES(K,J0)⊕GHASH2) = GHASH1 ⊕ GHASH2
  2. Tag长度安全
    • 96位Tag → 暴力破解概率≈1/2⁹⁶(安全)
    • 64位Tag → 暴力破解仅需分钟级(危险!)

📊 GCM性能优化(硬件加速)

平台密钥长度吞吐量加速技术
Intel AES-NIAES-25612 GB/s单指令完成AES轮函数
ARMv8 Crypto扩展AES-1285.2 GB/s并行CTR + PMULL指令
NVIDIA A100 GPUAES-256240 GB/s万级并发CTR计数器流

💡设计建议:TLS 1.3等协议强制使用GCM,因其在10Gbps网络下CPU占用率<3%。


💎总结:GCM操作清单

  1. 生成随机Nonce(12字节)
  2. 计算认证子密钥 H = AESₖ(0¹²⁸)
  3. 构造计数器初值 J₀ = Nonce || 0x00000001
  4. CTR模式加密:C = AESₖ(J₀+1) ⊕ P
  5. GHASH认证:T' = GHASHₕ(AAD || C || len(AAD) || len(C))
  6. 生成标签:T = AESₖ(J₀) ⊕ T'
  7. 输出 (C, T)

最后警示
始终通过恒定时间比较验证标签(防时序攻击),并遵循NIST SP 800-38D标准实现。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/22 5:27:27

网盘直链解析神器:一键突破下载限制的终极解决方案

网盘直链解析神器&#xff1a;一键突破下载限制的终极解决方案 【免费下载链接】netdisk-fast-download 各类网盘直链解析, 已支持蓝奏云/奶牛快传/移动云云空间/UC网盘/小飞机盘/亿方云/123云盘等. 预览地址 https://lz.qaiu.top 项目地址: https://gitcode.com/gh_mirrors/…

作者头像 李华
网站建设 2026/2/17 7:05:25

5分钟快速上手DownKyi:B站超高清视频下载终极指南

5分钟快速上手DownKyi&#xff1a;B站超高清视频下载终极指南 【免费下载链接】downkyi 哔哩下载姬downkyi&#xff0c;哔哩哔哩网站视频下载工具&#xff0c;支持批量下载&#xff0c;支持8K、HDR、杜比视界&#xff0c;提供工具箱&#xff08;音视频提取、去水印等&#xff0…

作者头像 李华
网站建设 2026/2/21 1:48:30

LangChain 1.0 VS LangGraph 1.0:智能体我该用哪一个?

今年正式发布了LangChain 1.0与LangGraph 1.0两大核心框架的正式版本&#xff0c;这不是一场简单的版本升级&#xff0c;而是一次面向AI智能体&#xff08;Agent&#xff09;规模化生产应用的关键进化。在当今快速发展的 AI 领域&#xff0c;两个最受欢迎的 AI 框架正日益壮大并…

作者头像 李华
网站建设 2026/2/22 6:08:06

终极Flash浏览器:告别无法播放的困扰,轻松访问经典Flash内容

终极Flash浏览器&#xff1a;告别无法播放的困扰&#xff0c;轻松访问经典Flash内容 【免费下载链接】CefFlashBrowser Flash浏览器 / Flash Browser 项目地址: https://gitcode.com/gh_mirrors/ce/CefFlashBrowser 在现代浏览器纷纷抛弃Flash支持的时代&#xff0c;你是…

作者头像 李华
网站建设 2026/2/6 11:44:58

诗歌创作挑战:LobeChat写出七律唐诗

诗歌创作挑战&#xff1a;LobeChat写出七律唐诗 在AI能写代码、做设计、甚至通过图灵测试的今天&#xff0c;一个更微妙的问题浮出水面&#xff1a;它能不能真正理解并创作有格律、有意境、有文脉的古典诗词&#xff1f; 这不是简单的文字拼接&#xff0c;而是对语言韵律、文化…

作者头像 李华
网站建设 2026/2/17 1:48:49

Google Drive下载神器:gdrivedl使用完全指南

Google Drive下载神器&#xff1a;gdrivedl使用完全指南 【免费下载链接】gdrivedl Google Drive Download Python Script 项目地址: https://gitcode.com/gh_mirrors/gd/gdrivedl 还在为Google Drive大文件下载烦恼吗&#xff1f;遇到下载配额限制不知如何是好&#xf…

作者头像 李华