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

Java中实现MD5加密主要通过java.security.MessageDigest类来完成。MD5(Message Digest Algorithm 5)是一种广泛使用的哈希算法,能够将任意长度的数据转换为一个128位(16字节)的摘要值,通常以32位十六进制字符串表示。
以下是使用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免费学习笔记(深入)”;
hexString.toString().toUpperCase()
MD5常用于密码存储、文件校验、数据指纹等场景,但不推荐用于高安全场景下的密码保护,因为MD5已被证明存在碰撞漏洞。
以上就是java怎么实现MD5加密 使用Java生成MD5摘要的实现方法的详细内容,更多请关注php中文网其它相关文章!
java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号