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位和后四位的十六进制数值
下一篇: thinkphp5 生成二维码