【Java】Java实现MD5、SHA-1、SHA-256、SHA-512加密

文章目录

        • 1 散列函数(也叫作hash函数)
          • 1.1 消息摘要
          • 1.2 特点
          • 1.3 常见算法
          • 1.4 代码实现

1 散列函数(也叫作hash函数)
1.1 消息摘要
  • 消息摘要(Message Digest)又称数字摘要(Digital Digest)。
  • 他是一个唯一对应一个消息或者文本的固定长度的值,它是一个单向的hash加密函数对消息进行作用而产生的。
  • 使用数字摘要生成的值是不可以篡改的,为了保证文件或者值的安全。
1.2 特点
  • 无论消息有多长,计算出来的消息摘要的长度总是固定的。例如用MD5算法摘要的消息有128个比特位,用SHA-1算法摘要的消息有160比特位的输出。
  • 只要输入的消息不同,对其进行摘要后产生的摘要消息也必定不相同,但是相同的输入必会产生相同的输出。
  • 消息摘要是单向的不可逆的。
1.3 常见算法

MD5、SHA-1、SHA-256、SHA-512

1.4 代码实现
package com.lh.basecryptology.digest;

import com.sun.org.apache.xerces.internal.impl.dv.util.Base64;

import java.security.MessageDigest;

public class DigestDemo {

    public static void main(String[] args) throws Exception {
        // 原文
        String text ="Aa";
        // 算法
        String algorithm = "MD5";
        String base64 = encryptMD5Base64(text, algorithm);
        System.out.println("Base64: " + base64);

        String md5 = encrypt(text, algorithm);
        System.out.println("MD5: " + md5);

        algorithm = "SHA-1";
        String sha1 = encrypt(text, algorithm);
        System.out.println("SHA-1: " + sha1);

        algorithm = "SHA-256";
        String sha256 = encrypt(text, algorithm);
        System.out.println("SHA-256: " + sha256);

        algorithm = "SHA-512";
        String sha512 = encrypt(text, algorithm);
        System.out.println("SHA-512: " + sha512);

    }

    /**
     *
     * @param text 原文
     * @param algorithm 算法
     * @return 密文
     * @throws Exception
     */
    private static String encryptMD5Base64(String text, String algorithm) throws Exception {
        // 获取数字摘要对象
        MessageDigest messageDigest = MessageDigest.getInstance(algorithm);
        // 加密
        byte[] digest = messageDigest.digest(text.getBytes());
        // base64转码
        return Base64.encode(digest);
    }

    /**
     * 加密转16进制
     * @param text 原文
     * @param algorithm 算法
     * @return 密文
     * @throws Exception 异常
     */
    private static String encrypt(String text, String algorithm) throws Exception {
        // 获取数字摘要对象
        MessageDigest messageDigest = MessageDigest.getInstance(algorithm);
        // 加密
        byte[] digest = messageDigest.digest(text.getBytes());
        // 对密文进行迭代转换成16进制
        StringBuilder sb = bytes2HexString(digest);
        return sb.toString();
    }

    /**
     * 字节数组转16进制字符
     * @param digest 数组
     * @return 结果
     */
    private static StringBuilder bytes2HexString(byte[] digest) {
        StringBuilder sb = new StringBuilder();
        for (byte b : digest) {
            String s = Integer.toHexString(b & 0xff);
            if(s.length()==1){
                s = "0"+s;
            }
            sb.append(s);
        }
        return sb;
    }
}

你可能感兴趣的:(密码学,java,md5,加密解密)