使用MessageDigest类可实现Java中的MD5加密,通过getInstance("MD5")获取实例,将字符串转为字节数组并计算摘要,再转为32位十六进制字符串;需处理null输入、统一编码(如UTF-8),输出通常小写,可转大写;MD5存在碰撞漏洞,不推荐用于高安全场景密码存储,建议加盐或使用BCrypt等更强算法。

Java中实现MD5加密主要通过java.security.MessageDigest类来完成。MD5(Message Digest Algorithm 5)是一种广泛使用的哈希算法,能够将任意长度的数据转换为一个128位(16字节)的摘要值,通常以32位十六进制字符串表示。
使用MessageDigest生成MD5摘要
以下是使用Java标准库生成字符串MD5值的基本步骤:
说明: 将字符串转为字节数组,使用MessageDigest处理后得到摘要,再将字节转换为十六进制字符串。
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
public class MD5Util {
public static String getMD5(String input) {
try {
MessageDigest md = MessageDigest.getInstance("MD5");
byte[] messageDigest = md.digest(input.getBytes());
StringBuilder hexString = new StringBuilder();
for (byte b : messageDigest) {
String hex = Integer.toHexString(0xff & b);
if (hex.length() == 1) {
hexString.append('0');
}
hexString.append(hex);
}
return hexString.toString();
} catch (NoSuchAlgorithmException e) {
throw new RuntimeException("MD5算法不可用", e);
}
}
// 测试示例
public static void main(String[] args) {
System.out.println(getMD5("hello world")); // 输出: 5eb63bbbe01eeed093cb22bb8f5acdc3
}
}
处理空值和大小写问题
实际应用中需注意输入为空或null的情况,避免异常。同时,MD5输出一般为小写,若需要大写可调用toUpperCase()
立即学习“Java免费学习笔记(深入)”;
- 对null输入做判空处理,返回默认值或抛出异常
- 若要求大写格式,可用
hexString.toString().toUpperCase() - 确保字符编码一致(如UTF-8),避免跨平台差异
常见用途与注意事项
MD5常用于密码存储、文件校验、数据指纹等场景,但不推荐用于高安全场景下的密码保护,因为MD5已被证明存在碰撞漏洞。
- 存储密码建议使用BCrypt、PBKDF2或SCrypt等慢哈希算法
- 若仅用于校验文件完整性,MD5仍可接受
- 可加盐(salt)增强安全性:在原文前或后拼接随机字符串再计算MD5











