java md5加解密
时间: 2023-08-30 21:11:52 浏览: 94
Java中的MD5加解密可以通过使用java.security.MessageDigest类来实现。下面是一个示例代码来进行MD5加密和解密:
```java
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
public class MD5Example {
public static void main(String[] args) {
String originalMessage = "Hello, World!";
// 加密
String encryptedMessage = encrypt(originalMessage);
System.out.println("Encrypted message: " + encryptedMessage);
// 解密(MD5是不可逆的加密算法,无法进行解密)
// 这里只是用原始消息重新计算MD5值,并与加密后的值进行比较,判断是否匹配
boolean isMatch = compare(originalMessage, encryptedMessage);
System.out.println("Is original message and encrypted message match? " + isMatch);
}
private static String encrypt(String originalMessage) {
try {
MessageDigest md = MessageDigest.getInstance("MD5");
md.update(originalMessage.getBytes());
byte[] digest = md.digest();
StringBuilder encryptedMessage = new StringBuilder();
for (byte b : digest) {
encryptedMessage.append(String.format("%02x", b & 0xff));
}
return encryptedMessage.toString();
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
return null;
}
}
private static boolean compare(String originalMessage, String encryptedMessage) {
String encryptedOriginalMessage = encrypt(originalMessage);
return encryptedOriginalMessage.equals(encryptedMessage);
}
}
```
请注意,MD5是不可逆的加密算法,无法直接进行解密。以上代码仅用于将原始消息重新计算MD5值,并与加密后的值进行比较,判断是否匹配。
阅读全文