SM3算法

【实验目的】

1、理解Hash函数的计算原理和特点
2、理解SM3算法原理
3、了解SM3值的生成过程

【实验环境】

用户A需要生成一段消息的SM3值,准备依据这个散列值对消息进行进一步的处理。
完成本实验需要使用密码学教学软件,在D:\Release\bin目录下打开Crypto软件。

【实验预备知识点】

SM3算法是密码杂凑算法,适用于商用密码应用中的数字签名和验证、消息认证码的生成与验证以及随机数的生成,可满足多种密码应用的安全需求。
对长度为l(l< 2^64) 比特的消息m,SM3杂凑算法经过填充和迭代压缩,生成杂凑值,杂凑值长度为256比特。具体过程请见SM3标准描述。

【实验内容】

SM3算法是国家密码管理局2010年12月颁布的密码杂凑算法,适用于商用密码应用中的数字签名和验证、消息认证码的生成与验证以及随机数的生成。

SM3算法对于长度小于264位的消息,产生一个256位的消息摘要。

算法以512位分组来处理输入的信息,每一分组又被划分为132个32位子分组,经过一系列的处理后,算法的输出由八个32位分组组成,将这些32位分组级联后产生一个256位的散列值。

【实验步骤】

(1). 输入消息
(2). 点击生成按钮
(3). 观察明文填充块,观察生成的散列值
(4). 点击64步运算按钮,观察SM3运算的各个步骤
(5). 对输入消息做细微修改
(6). 重复(2),(3),(4)
(7). 比较散列值前后的变化情况

  • 0
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
Java中的SM3算法是一种密码学哈希函数,用于生成消息摘要。它是中国国家密码管理局发布的一种国家标准算法,适用于数字签名、身份认证等安全领域。 SM3算法的特点如下: 1. 输入和输出都是256位(32字节)的消息摘要。 2. 具有较高的安全性和抗碰撞能力,能够有效防止碰撞攻击。 3. 算法设计简洁,运算速度较快。 在Java中使用SM3算法,可以通过Java的安全包`java.security`中的`MessageDigest`类来实现。以下是使用Java实现SM3算法的示例代码: ```java import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; public class SM3Example { public static void main(String[] args) { String message = "Hello, SM3!"; try { // 创建MessageDigest对象并指定算法为"SM3" MessageDigest md = MessageDigest.getInstance("SM3"); // 将消息转换为字节数组 byte[] messageBytes = message.getBytes(); // 计算消息摘要 byte[] digest = md.digest(messageBytes); // 将摘要转换为十六进制字符串 StringBuilder sb = new StringBuilder(); for (byte b : digest) { sb.append(String.format("%02x", b)); } System.out.println("Message: " + message); System.out.println("Digest: " + sb.toString()); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } } } ``` 以上代码中,首先创建了一个`MessageDigest`对象,并指定算法为"SM3"。然后将待计算摘要的消息转换为字节数组,通过调用`digest`方法计算消息摘要。最后将摘要转换为十六进制字符串进行展示。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值