java HMAC_SHA1加密算法

Posted Marydon

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java HMAC_SHA1加密算法相关的知识,希望对你有一定的参考价值。

java HMAC_SHA1加密算法

CreationTime--2018年7月14日16点46分

Author:Marydon

1.准备工作

import javax.crypto.Mac;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import org.apache.log4j.Logger;

/**
 * HMAC_SHA1加密算法工具类
 * @explain 不可逆算法
 * @author Marydon
 * @creationTime 2018年7月7日上午11:06:58
 * @version 1.0
 * @since
 * @email
 */
public class HMAC_SHA1Utils {

    private static Logger log = Logger.getLogger(HMAC_SHA1Utils.class);
    // 加密方法
    private static final String MAC_NAME = "HmacSHA1";
    // 定义字符集
    private static final String ENCODING = "UTF-8";
}

2.HMAC_SHA1加密

/**
 * 使用HMAC_SHA1算法进行加密
 * @explain
 * @param paramStr
 *            待加密字符串
 * @param key
 *            密钥(长度不限、可以为中文、英文、16进制字符串)
 * @return 16进制加密字符串,长度固定为40
 * @throws Exception
 */
public static String encrypt(String paramStr, String key) {
    // 用于存储加密后的16进制字符串
    String cipher = "";
    try {
        //
        byte[] data = key.getBytes(ENCODING);
        // 根据给定的字节数组构造一个密钥,第二参数指定一个密钥算法的名称
        // 生成HmacSHA1专属密钥
        SecretKey secretKey = new SecretKeySpec(data, MAC_NAME);
        // 生成一个指定 Mac 算法 的 Mac 对象
        Mac mac = Mac.getInstance(MAC_NAME);
        // 用给定密钥初始化 Mac 对象
        mac.init(secretKey);
        byte[] text = paramStr.getBytes(ENCODING);
        // 完成 Mac 操作
        byte[] encryptByte = mac.doFinal(text);
        // 将byte[]-->hexString
        cipher = ByteUtils.toHex(encryptByte);
    } catch (Exception e) {
        e.printStackTrace();
        log.error("HMACSHA1加密失败:" + e.getMessage());
    }
    log.info("HMACSHA1加密结果:" + cipher);
    return cipher;
}

3.校验

/**
 * 判断源数据与加密数据是否一致
 * @explain
 * @param srcStr
 *            原字符串
 * @param secretStr
 *            16进制加密字符串
 * @param key
 *            密钥
 * @return 校验结果
 */
public static boolean verify(String srcStr, String secretStr, String key) {
    boolean flag = false;
    String cipherText = encrypt(srcStr, key);
    if (cipherText.equals(secretStr))
        flag = true;
    return flag;
}

4.测试

/**
 * 测试
 * @param args
 */
public static void main(String[] args) {

    String json = "{\\"name\\":\\"Marydon\\",\\"website\\":\\"http://www.cnblogs.com/Marydon20170307\\"}";
    String key = "测试";
    String cipher = HMAC_SHA1Utils.encrypt(json, key);
    System.out.println(cipher);
    System.out.println(HMAC_SHA1Utils.verify(json, cipher, key));

}

 

以上是关于java HMAC_SHA1加密算法的主要内容,如果未能解决你的问题,请参考以下文章

MD5 SHA1 HMAC HMAC_SHA1区别

可以解密加密数据的片段吗?

片段(Java) | 机试题+算法思路+考点+代码解析 2023

如何使用 PKCS5_PBKDF2_HMAC_SHA1()

java加密算法入门-非对称加密详解

JAVA加密解密DES对称加密算法