Bootstrap

国产密码杂凑算法SM3

国产密码杂凑算法SM3

SM3是中华人民共和国政府采用的一种密码散列函数标准,由国家密码管理局于2010年12月17日发布。相关标准为“GM/T0004-2012《SM3密码杂凑算法》”。在商用密码体系中,SM3主要用于数字签名及验证、消息认证码生成及验证、随机数生成等,其算法公开。据国家密码管理局表示,其安全性及效率与SHA-256相当。

SM3算法中的常量和布尔函数。

移位寄存器(A,B,C,D,E,F,G,H)的初始值:

轮常数:

布尔函数:

等价于

置换函数:

消息扩展算法:

将消息分组B(i)按以下方法扩展生成132个字W0,W1,……,W67;W0`,W1`,……,W63`,用于压缩函数CF。将消息分组B(i)划分为16个字W0,W1,……,W15。

计算出W0,W1,……,W67。

然后计算出W0`,W1`,……,W63`。

消息压缩算法:

A,B,C,D,E,F,G,H为32比特的移位寄存器,SS1,SS2,TT1,TT2为中间变量。

压缩函数可表示为:

详细计算过程描述如下:

V(n)即为输出的256比特的杂凑值。

SM3密码杂凑算法广泛应用于数字签名、完整性保护、安全认证、口令保护、消息认证码的生成与验证、文件验证、数据库存储与索引以及随机数生成等场合。是一种安全、高效且已标准化的密码杂凑算法,具有广泛的应用前景和重要的战略意义。