不可逆哈希算法-HMAC

一:百科

HMAC运算利用hash算法,以一个消息M和一个密钥K作为输入,生成一个定长的消息摘要作为输出。支持的算法包括:MD5,sha1、sha256、SM3等。是以HMAC-MD5,HMAC-SM3的HMAC-X命名。

二:目的

由于要求,需要使用HMAC-SM3来验证消息的完整性和真实性,确保数据在传输和存储过程中不被篡改。

三:测试

SM3不在Java标准库中,需要添加jar包

四:代码

public static String hmacSm3(String data,String key){
        Digest digest=new SM3Digest();
        HMac hmac=new HMac(digest);
        hmac.init(new KeyParameter(key.getBytes()));
        hmac.update(data.getBytes(StandardCharsets.UTF_8),0,data.getBytes().length);
        byte[] hmac_sm3=new byte[hmac.getMacSize()];
        hmac.doFinal(hmac_sm3, 0);
        return Hex.toHexString(hmac_sm3);
    }

五:其他子类

Digest digest1=new MD5Digest();
Digest digest2=new SHA1Digest();

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值