使用 SM3 加密方式的方法

本文介绍了如何在Java项目中将密码加密方式从MD5升级为更安全的SM3,使用了BCprov-jdk18on-1.77.jar库和BcSm3Util类,展示了SM3Digest和HMAC-SM3的实现过程。
摘要由CSDN通过智能技术生成

项目改造,升级用户登录中密码的加密方式,由MD5改为SM3方式。

使用jar包:bcprov-jdk18on-1.77.jar

使用类:BcSm3Util.java

SM3

import org.bouncycastle.crypto.digests.SM3Digest;
import org.bouncycastle.crypto.macs.HMac;
import org.bouncycastle.crypto.params.KeyParameter;
import org.bouncycastle.jce.provider.BouncyCastleProvider;
import org.bouncycastle.util.encoders.Hex;

import java.security.MessageDigest;
import java.security.Security;

/**
 * sm3加密方法
 */
public class BcSm3Util {

    static {
        Security.addProvider(new BouncyCastleProvider());
    }

    public static byte[] sm3(byte[] srcData) {
        SM3Digest sm3Digest = new SM3Digest();
        sm3Digest.update(srcData, 0, srcData.length);
        byte[] hash = new byte[sm3Digest.getDigestSize()];
        sm3Digest.doFinal(hash, 0);
        return hash;
    }

    public static String sm3Hex(byte[] srcData) {
        byte[] hash = sm3(srcData);
        String hexString = org.apache.commons.codec.binary.Hex.encodeHexString(hash);
        return hexString;
    }

    public static byte[] hmacSm3(byte[] key, byte[] srcData) {
        KeyParameter keyParameter = new KeyParameter(key);
        SM3Digest digest = new SM3Digest();
        HMac mac = new HMac(digest);
        mac.init(keyParameter);
        mac.update(srcData, 0, srcData.length);
        byte[] hash = new byte[mac.getMacSize()];
        mac.doFinal(hash, 0);
        return hash;
    }

    public static String hmacSm3Hex(byte[] key, byte[] srcData) {
        byte[] hash = hmacSm3(key, srcData);
        String hexString = org.apache.commons.codec.binary.Hex.encodeHexString(hash);
        return hexString;
    }

    public static byte[] sm3bc(byte[] srcData) throws Exception {
        MessageDigest messageDigest = MessageDigest.getInstance("SM3", "BC");
        byte[] digest = messageDigest.digest(srcData);
        return digest;
    }

    public static String sm3bcHex(byte[] srcData) throws Exception {
        byte[] hash = sm3bc(srcData);
        String hexString = org.apache.commons.codec.binary.Hex.encodeHexString(hash);
        return hexString;
    }

    /**
     * 获取SM3加密结果字符串
     *
     * @param srcData
     * @return
     * @throws Exception
     */
    public static String getSM3ofStr(String srcData) {
        System.out.println("getSM3ofStr加密--进入参数>>>>>>>>" + srcData);
        SM3Digest digest = new SM3Digest();
        byte[] input = srcData.getBytes();
        digest.update(input, 0, input.length);
        byte[] result = new byte[digest.getDigestSize()];
        digest.doFinal(result, 0);
        String digestHex = Hex.toHexString(result);
        System.out.println("getSM3ofStr加密--进入结果>>>>>>>>>>>>>>>>" + digestHex);
        return digestHex;
    }

    public static void main(String[] args) {
        String message = "password";
        String digestHex = BcSm3Util.getSM3ofStr(message);
        System.out.println("加密后-->" + digestHex);
    }

  • 8
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值