关于密码学:密码学-05-MAC算法

MAC系列算法

1. 特点

MAC算法与MD和SHA的区别是多了一个密钥,密钥能够随机给

2. java实现

public static String getMAC(String plaintext) throws NoSuchAlgorithmException, InvalidKeyException {
        // 生成秘钥 
        SecretKeySpec skp1 = new SecretKeySpec("12345678".getBytes(StandardCharsets.UTF_8),"HmacSHA1");
        // 应用 字符串 a123456789 中索引 1 开始,计算8位为秘钥
        SecretKeySpec skp2 = new SecretKeySpec("a123456789".getBytes(StandardCharsets.UTF_8),1,8,"HmacSHA1");
        //   通过 getEncoded 失去秘钥
        String key = new String(skp1.getEncoded());
        // 通过 getAlgorithm 失去加密算法
        String algorithm = skp1.getAlgorithm();
        // 生成 Mac 算法实例
        Mac mac = Mac.getInstance(algorithm);
        // 初始化 mac 对象
        mac.init(skp1);
        
        String saltstr = "saltstr";
        // 加盐操作
        mac.update(saltstr.getBytes(StandardCharsets.UTF_8));
        // 最初失去加密后的byte列表
        byte[] bty  = mac.doFinal(plaintext.getBytes(StandardCharsets.UTF_8));
        // 生成 ByteString 对象
        ByteString res = ByteString.of(bty);
        // 调用hex 和base64 办法  失去编码后的值  
        String resHex = res.hex();
        String resBase64 = res.base64();

        return resHex+"||"+resBase64;
    }

3. 加密后的字节数组能够编码成Hex、Base64

4. 没有任何输出,也能计算hash值

评论

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

这个站点使用 Akismet 来减少垃圾评论。了解你的评论数据如何被处理