SM3算法


前言

提示:以下是本篇文章正文内容,下面案例可供参考

一、SM3是什么?

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

二、go语言实现

package main

import (
	"github.com/tjfoc/gmsm/sm3"
	"fmt"
	"encoding/hex"
)

func main13_1() {
	hash := sm3.New()
	hash.Write([]byte("wei"))
	result := hash.Sum(nil)
	fmt.Println(hex.EncodeToString(result))
	fmt.Println("length = ", len(result)*8)
}

func main() {
	result := sm3.Sm3Sum([]byte("wei"))
	fmt.Println("length = ", len(result) * 8)
	fmt.Println(hex.EncodeToString(result))
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
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`方法计算消息摘要。最后将摘要转换为十六进制字符串进行展示。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值