两种常用的哈希算法与Hmac算法

本文详细介绍了三种常见的哈希算法:MD5、SHA-1以及HMAC的步骤与Java代码实现。MD5用于获取固定长度的摘要,SHA-1增加了加盐的步骤以提高安全性,而HMAC则涉及到了密钥的生成与使用,增强了数据的安全性。这些算法在数据校验和信息安全中起着关键作用。
摘要由CSDN通过智能技术生成

目录

0.概述:

1、MD5算法

1.1 步骤

1.2代码实现

2 、SHA-1算法

2.1 步骤

2.2 代码实现:

3 、Hmac算法

3.1 步骤:

3.2 代码实现:


0.概述:

哈希算法又称摘要算法,它的作用是:对任意一组输入数据进行计算,得到一个固定长度的输出摘要。哈希算法的目的:为了验证原始数据是否被篡改。

最主要的特点是:

  • 相同的输入一定得到相同的输出

  • 不同的输入大概率得到不同的输出

1、MD5算法

1.1 步骤

  • 获取基于MD5加密算法的工具对象

  • 更新原始数据

  • 获取加密后的结果

  • 将字节数组形式的结果转换成字符串

1.2代码实现

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
​
/*
 * MD5加密密码,规定长度为32,并且拿到他的字符串形式
 */
public class Test02 {
    public static void main(String[] args) {
        String password = "wbjxxmynhmyzgq";
        try {
            MessageDigest digest = MessageDigest.getInstance("MD5");
            digest.update(password.getBytes());
            byte[] digestByteArray = digest.digest();//加密
            StringBuilder result = new StringBuilder();
            for(byte b : digestByteArray) {
                result.append(String.format("%02x", b));
            }
            System.out.println(result.toString());
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
        }
    }
}

2 、SHA-1算法

2.1 步骤

  • 获取基于MD5加密算法的工具对象(“SHA-1”)

  • 更新原始数据

  • 获取加密后的结果

  • 将字节数组形式的结果转换成字符串

2.2 代码实现:

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.Arrays;
import java.util.UUID;
/*
 * SHA-1哈希算法
 */
public class Test01 {
    public static void main(String[] args) {
        String password = "sdfsdf";
        //加盐
        String salt = UUID.randomUUID().toString().substring(0, 5);
        System.out.println(salt);
        try {
            //SHA-1哈希算法
            MessageDigest digest = MessageDigest.getInstance("SHA-1");
            digest.update(password.getBytes());
            digest.update(salt.getBytes());
            byte[] digestArray = digest.digest();
            StringBuilder resultStr = new StringBuilder();
            for(byte b : digestArray){
                resultStr.append(String.format("%02x", b));
            }
            System.out.println(resultStr.toString());
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
        }
    }
}

3 、Hmac算法

3.1 步骤:

  • 生成秘钥(创建秘钥生成器对象)

  • 利用秘钥生成器生成秘钥

  • 生成秘钥Key的字节数组

  • 可以将秘钥字节数组转换成字符串

  • 使用秘钥、进行加密(获取算法对象)

  • 初始化

  • 更新原始内容

  • 加密,生成字节数组形式的加密结果

  • 将加密结果转换成字符串

3.2 代码实现:

public class Test01 {
    public static void main(String[] args) {
        try{
        //1 获取秘钥结果
        String password = "nhmyzgq";
        //秘钥生成器
      KeyGenerator keyGen = KeyGenerator.getInstance("HmacMD5");
        //生成秘钥
        SecretKey key = keyGen.generateKey();
        //生成秘钥数组
        byte[] keyByteArray = key.getEncoded();
        StringBuilder sb = StringBuilder();
        for(byte b:keyByteArray) {
            sb.append(String.format("%02x", b));
        }
        System.out.println("打印秘钥内容:" + sb);
         //2使用秘钥,进行加密
        //获取算法对象
        Mac mac = Mac.getInstance("HmacMD5");
        //初始化
        mac.init(key);
        mac.update(password.getBytes());
        //加密(返回字节数组)
        byte[] resultByteArray = mac.doFinal();
        //把字节数组转换成字符串
        StringBuilder resultStr = new StringBuilder();
        for(byte b : resultByteArray){
            resultStr.append(String.format("%02", b));
        }
        System.out.println(resultStr);
    }catch(NoSuchAlgorithmException e){
            e.printStackTrace();
     }
    }
}
恢复秘钥的代码实现:
public class Test01 {
    public static void main(String[] args) {
        try{
        //1 获取秘钥结果
        String password = "nhmyzgq";
        //秘钥生成器
      KeyGenerator keyGen = KeyGenerator.getInstance("HmacMD5");
        //生成秘钥
        SecretKey key = keyGen.generateKey();
        //生成秘钥数组
        byte[] keyByteArray = key.getEncoded();
        StringBuilder sb = StringBuilder();
        for(byte b:keyByteArray) {
            sb.append(String.format("%02x", b));
        }
        System.out.println("打印秘钥内容:" + sb);
         //2使用秘钥,进行加密
        //获取算法对象
        Mac mac = Mac.getInstance("HmacMD5");
        //初始化
        mac.init(key);
        mac.update(password.getBytes());
        //加密(返回字节数组)
        byte[] resultByteArray = mac.doFinal();
        //把字节数组转换成字符串
        StringBuilder resultStr = new StringBuilder();
        for(byte b : resultByteArray){
            resultStr.append(String.format("%02", b));
        }
        System.out.println(resultStr);
    }catch(NoSuchAlgorithmException e){
            e.printStackTrace();
     }
    }
}

  • 21
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
HMAC算法和循环冗余算法(CRC)是两种完全不同的算法,用于不同的目的。下面分别介绍一下它们的特点和用途。 HMAC算法 HMAC(Hash-based Message Authentication Code)算法是一种基于哈希函数的消息认证码算法。它通过将密钥和消息作为输入,生成一个固定长度的认证码,用于验证消息的完整性和真实性。 HMAC算法的主要特点包括: 1. 基于哈希函数,具有高度安全性和不可逆性。 2. 通过引入密钥,增强了消息的安全性,避免了被篡改或伪造的风险。 3. 可以用于验证消息的完整性和真实性,以及识别伪造或篡改的消息。 HMAC算法广泛应用于网络安全领域,例如SSL、IPsec、SSH等协议中,用于保护通信过程中的数据安全和完整性。 循环冗余算法(CRC) 循环冗余算法(CRC)是一种根据数据位的内容生成校验码的算法。它通过将数据按位进行异或运算,生成一个固定长度的校验码,用于检测数据传输过程中的错误。 CRC算法的主要特点包括: 1. 可以检测出单比特差错、双比特差错、奇偶差错等多种错误。 2. 通过生成一个固定长度的校验码,可以在传输数据时快速检测数据的完整性,提高数据传输的可靠性。 3. 由于CRC算法的计算速度较快,因此被广泛应用于计算机网络、数据存储等领域。 总体来说,HMAC算法和CRC算法都是常见的数据安全算法,用于不同的领域和目的。HMAC算法主要用于验证消息的完整性和真实性,而CRC算法主要用于检测数据传输过程中的错误。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值