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

sm3加密算法

Sm3加密算法

SM3是中国国家密码管理局2010年发布的商用密码杂凑算法标准,生成256位固定长度的哈希值,适用于数字签名、消息认证、密码存储等场景。其设计基于Merkle-Damgård结构,安全性等效于国际SHA-256算法,但采用定制化的压缩函数增强抗攻击能力。

二、核心流程
  1. 消息填充将输入补足至512位倍数(补1+0...0+64位消息长度)
  2. 消息扩展将512位分组扩展为132个32位字
  3. 迭代压缩通过64轮压缩函数更新8个寄存器状态

结果生成最终寄存器组合输出256位哈希值

算法的本质给任意长度的数据(l≤264)经过填充、迭代压缩后,生成固定长度的杂凑值,这个固定长度就是256比特

处理过程:

第一步:填充。使填充后的数据的长度是512的整数倍。在数据的末尾上加一个1;然后把原始数据的长度用64比特表示,放在最后面;再看看现在的数据的长度值离512的整数还差多少个,差多少个就填多少个0在加的这个1和64比特的长度之间。

第二步:分组。把填充后的信息按照512比特一个分组进行分组。如果分成了n组,就是B0,B1,…,Bn−1个分组。

第三步:迭代压缩。对每一个分组都进行消息扩展,再借助寄存器得到最后的杂凑值(哈希值)。迭代压缩这里有很多中间变量和寄存器的操作,具体还是看一下算法。

分组的目的是为了把填充后的消息m′能拆成512比特,在对每个512比特分别进行扩展和迭代压缩。

前一个分组的结果会参与下一个分组的迭代压缩计算。

经过一连串的迭代计算后,最终寄存器中的结果为SM3算法处理得到的杂凑值。

2. 相关符号和函数

2.1 一些符号定义

mod

模运算

32比特与运算

32比特或运算

¬

32比特非运算

32比特异或运算
(由于输入法打不出这个符号,因此下面的配图里用xor代替了)

+

mod223算数加运算

⋘k

循环左移k比特运算

左向赋值运算符

2.2 一些固定值和函数

初始值:

IV=7380166f4914b2b9172442d7da8a0600a96f30bc163138aae38dee4d b0fb0e4e

常量:

Tj={79cc45190≤j≤157a879d8a16≤j≤63

布尔函数:

FFj(X,Y,Z)={X⊕Y⊕Z0≤j≤15(X∧Y)∨(X∧Z)∨(Y∧Z)16≤j≤63

GGj(X,Y,Z)={X⊕Y⊕Z0≤j≤15(X∧Y)∨(¬X∧Z)16≤j≤63

式中X,Y,Z为字。

置换函数:

P0(X)=X⊕(X⋘9)⊕(X⋘17)

P1(X)=X⊕(X⋘15)⊕(X⋘23)

式中X为字。

3. 算法流程

3.1 填充

假设消息m的长度为l比特。

首先将比特“1”添加到消息的末尾,再添加k个"0",k是满足l+1+k≡448mod512的最小非负整数。

然后再添加一个64位比特串,该比特串是长度l的二进制表示。

填充后的消息m′的比特长度为512的倍数。

3.2 分组

将填充后的消息m′按512比特进行分组:m′=B0B1…Bn−1,n=(l+k+65)/512

3.3 迭代压缩

3.3.1 消息扩展

将消息分组Bi按以下方法扩展生成132个字W0,W1,…,W67,W′0,W′1,⋯,W′63。

每一个分组Bi都需要扩展成这么多的字,每一个结果都会作为压缩函数的中间参数参与迭代计算。

a) 将消息分组Bi划分为16个字W0,W1,…,W15;

b) FOR j=16 TO 67

​ Wj←P1(Wj−16⊕Wj−9⊕(Wj−3⋘15))⊕(Wj−13⋘7)⊕Wj−6

ENDFOR

c) FOR j=0 TO 63

​ W′j=Wj⊕Wj+4

ENDFOR

3.3.2 压缩函数

令A,B,C,D,E,F,G,H为字寄存器,SS1, SS2, TT1, TT2为中间变量,压缩函数Vi+1=CF(V(i),B(i)),0≤i≤n−1

计算过程如下:

ABCDEFGH←V(i)

FOR j=0 TO 63

​ SS1←((A⋘12)+E+(Tj⋘j))⋘7

​ SS2←SS1⊕(A⋘12)

​ TT1←FFj(A,B,C)+D+SS2+W′j

​ TT2←(E,F,G)+H+SS1+Wj

​ D←C

​ C←B⋘9

​ B←A

​ A←TT1

​ H←G

​ G←F⋘19

​ F←E

​ E←P0(TT2)

ENDFOR

Vi+1←ABCDEFGH⊕V(i)

其中,字的存储为大端(big-endian)格式。

3.3.3 杂凑值结果

ABCDEFGH←V(n)

输出256比特的杂凑值y=ABCDEFGH。

http://www.zskr.cn/news/110455.html

相关文章:

  • 【UE5.3】使用Live Link Face给vrm角色添加表情和头部动作
  • EmotiVoice安装与环境配置指南
  • FLUX.1-Controlnet-Union新手快速配置指南
  • MySQL的索引底层数据结构?(B+树)为什么用B+树不用B树或哈希?
  • LobeChat能否应用于自动驾驶?车载语音助手升级
  • LangFlow实现社交媒体内容自动审核流程
  • 百度AI开放平台VS GPT-SoVITS:哪个更便宜?
  • Langflow自定义组件开发:从入门到实战
  • TensorRT镜像部署:从Git下载到Docker安装一步到位
  • 别再让你的多线程程序卡死!彻底掌握 POSIX 信号量在生产者-消费者模型中的同步与互斥
  • LobeChat能否用于创建客户画像?精准营销数据建模
  • 销量与口碑双赢:市场上最畅销的多重光散射仪是哪家? - 品牌推荐大师
  • Qwen3-8B-AWQ部署与长文本处理实战指南
  • Wan2.2-T2V-A14B + GPU:重塑AI视频生产力
  • 办公室下午茶小包装零食推荐:我工位抽屉里的“轻负担”组合(旺旺Fixbody) - AIEO
  • 基于鲹鱼优化算法的物流配送中心选址附Matlab代码
  • 国际象棋比赛数据:100万局专业对局数据库助力AI算法训练和棋艺分析研究
  • Seed-Coder-8B-Base实战:构建机器学习Pipeline
  • AI社交平台的用户体验设计:焦圈儿做了哪些创新?
  • 调节性 T 细胞(Tregs)科普
  • 社交+AI的化学反应:焦圈儿打造的新型互动模式
  • Dify部署实战:基于Docker Compose一键启动AI应用开发环境
  • 【文献阅读】DP-Site:一种基于双重深度学习的蛋白质-肽相互作用位点预测方法
  • 2025年实验室设备行业Top5服务商测评:贝加尔科技性价比 - 工业品牌热点
  • 河南音视频设备选哪家?艾可视:全链技术+本地化服务的2025优选 (4) - 朴素的承诺
  • 2025一物一码加工厂TOP5权威推荐:防伪溯源解决方案甄选 - myqiye
  • 2025年高性价比空气加热器工厂推荐:空气加热器制造商及厂家 - 工业推荐榜
  • 常用细胞培养基科普
  • 2025年店铺起名公司联系方式汇总:全国主流服务机构官方联系通道与合作价值解析 - 品牌推荐
  • 谁还能不知道计算机组成结构与缓存