欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Java md5加密实现

程序员文章站 2022-03-01 18:46:02
...

Java md5加密实现

md5算法是把任意一个字符串经过加密后得到一个16位的byte[]数组,也就是128位bit的串,所以md5值有2^128种可能。
2^128=340282366920938463463374607431768211456,这是非常大的一个数,md5是不可逆的,所以这是我们平时经常用到的一个加密算法,数据库存储的用户密码很多是md5算法加密后的


Java生成md5值代码

package com.lipenglong.tool.encrypt;

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;

/**
 * md5加密器类
 * <p/>
 * Created by lipenglong on 2017/8/10.
 */
public class MD5Encoder {
    private static final char[] HEX = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f'};

    /**
     * md5加密算法实现:使用Integer的toHexString()方法
     *
     * @param src 加密字符串
     * @return 加密后的md5串
     */
    public static String encode(String src) {
        try {
            MessageDigest md = MessageDigest.getInstance("MD5");
            md.update(src.getBytes());
            byte[] bytes = md.digest();
            StringBuffer buf = new StringBuffer();
            for (int i = 0; i < bytes.length; i++) {
                String s = Integer.toHexString(bytes[i] & 0xff);
                if (s.length() == 1) {
                    buf.append("0");
                }
                buf.append(s);
            }
            return buf.toString();
        } catch (NoSuchAlgorithmException e) {
            return null;
        }
    }

    /**
     * md5加密算法实现:定义一个16进制char数组,取每一个byte前后四
     * 位对应的char
     *
     * @param src 加密字符串
     * @return 加密后的md5串
     */
    public static String encode2(String src) {
        try {
            MessageDigest md = MessageDigest.getInstance("MD5");
            md.update(src.getBytes());
            byte[] bytes = md.digest();
            final int nBytes = bytes.length;
            char[] result = new char[2 * nBytes];
            int j = 0;
            for (int i = 0; i < nBytes; i++) {
                // Char for top 4 bits
                result[j++] = HEX[(0xF0 & bytes[i]) >>> 4];
                // Bottom 4
                result[j++] = HEX[(0x0F & bytes[i])];
            }
            return new String(result);
        } catch (NoSuchAlgorithmException e) {
            return null;
        }
    }
}

md5之后得到16位的byte[]数组,每一个byte转换成2位十六进制数值,所以md5后的String字符串是32位。上面的代码中有两种byte转十六进制的实现:

  • encode()方法使用Integer的toHexString()方法把byte转为十六进制,因为toHexString方法接收的参数为int类型,int是4个字节长度,所以执行byte[i]和0xff的按位于操作截取后8位,得到后8位的十六进制数值,然后判断十六进制值的长度,1位的话前面补个0
  • encode2()方法采用的spring security中的 Md5PasswordEncoder 类的实现方式,定义一个HEX十六进制char[]数组,分别取byte[i]前4位和后四位的十六进制数值