MD5是一种比较复杂的算法,对于MD5算法的说法很多,在很多地方都说MD5是不可逆的,具体的我也不是很清楚,
在这里我用一种比较简单的方式,仅供参考
package com.md5;
import java.math.BigInteger;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
public class MD5Utils {
/**
* 使用md5的算法进行加密
*/
public static String md5(String plainText) {
byte[] secretBytes = null;
//判断有没有md5算法
secretBytes = MessageDigest.getInstance("md5").digest( plainText.getBytes());
} catch (NoSuchAlgorithmException e) {
throw new RuntimeException("没有md5这个算法!");
}
// 16进制数字
String md5code = new BigInteger(1, secretBytes).toString(16);
// 如果生成数字未满32位,需要前面补0for (int i = 0; i < 32 - md5code.length(); i++) {
md5code = "0" + md5code;
}
return md5code;
}
//程序入口
public static void main(String[] args) {
System.out.println(md5("123456"));
}
}
上述代码可直接运行.........