@Service
@RequiredArgsConstructor
public class Md5Util {
public static String md5Encrypt(String string) {
try {
byte[] bytes = string.getBytes(StandardCharsets.UTF_8);
MessageDigest digest = MessageDigest.getInstance("md5");
byte[] result = digest.digest(bytes);
//对于加密后的结果进行输出:将字节数组转为16进制的字符串
StringBuffer sb = new StringBuffer();
for (byte b : result) {
int num = b & 0xff;//加盐,转类型的时候保证补码相同
String str = Integer.toHexString(num);
if(str.length() == 1){
sb.append("0");
}
sb.append(str);
}
return sb.toString();
}catch (Exception e){
e.printStackTrace();
}
return null;
}
//md5计算
public static String getMD5String(String str) {
try {
// 生成一个MD5加密计算摘要
MessageDigest messageDigest = MessageDigest.getInstance("MD5");
// 计算md5函数
messageDigest.update(str.getBytes(StandardCharsets.UTF_8));
// digest()最后确定返回md5 hash值,返回值为8位字符串。因为md5 hash值是16位的hex值,实际上就是8位的字符
// BigInteger函数则将8位的字符串转换成16位hex值,用字符串来表示;得到字符串形式的hash值
//一个byte是八位二进制,也就是2位十六进制字符(2的8次方等于16的2次方)
byte[] resultByteArray = messageDigest.digest();
// 字符数组转换成字符串返回
return byteArrayToHex(resultByteArray);
} catch (Exception e) {
e.printStackTrace();
return null;
}
}
/**
* 将字节数组换成成16进制的字符串
* @param byteArray
* @return
*/
public static String byteArrayToHex(byte[] byteArray) {
// 首先初始化一个字符数组,用来存放每个16进制字符
char[] hexDigits = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F' };
// new一个字符数组,这个就是用来组成结果字符串的(解释一下:一个byte是八位二进制,也就是2位十六进制字符(2的8次方等于16的2次方))
char[] resultCharArray = new char[byteArray.length * 2];
// 遍历字节数组,通过位运算(位运算效率高),转换成字符放到字符数组中去
int index = 0;
for (byte b : byteArray) {
resultCharArray[index++] = hexDigits[b >>> 4 & 0xf];
resultCharArray[index++] = hexDigits[b & 0xf];
}
// 字符数组组合成字符串返回
return new String(resultCharArray);
}
}
MD5工具包
最新推荐文章于 2024-09-08 10:55:14 发布