public class Md5Util {
/**
* 根据输入的字符串生成固定的32位MD5码
*
* @param str
* 输入的字符串
* @return MD5码
*/
public final static String getMd5(String str) {
MessageDigest mdInst = null;
try {
mdInst = MessageDigest.getInstance("MD5");
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
// 使用指定的字节更新摘要
mdInst.update(str.getBytes());
// 获得密文
byte[] md = mdInst.digest();
return StrConvertUtil.byteArrToHexStr(md);
}
public static void main(String[] args) {
System.out.println(Md5Util.getMd5("admin123abc"));
}
}
以上是加密把String字符串加密成32位MD5的代码。
请问各位大神 怎么把MD5在还原成String类型的字符串啊!!!!
首先MD5是不可逆的,他不是密码,是摘要
有库函数可以调用,自行查找,你要自己写也是可以的,看一下密码学,了解下MD5的生成原理就可以了
MD5不能还原成String的,就是说这是不能解密的,唯一可破解的方式是,结合彩虹表等进行MD5碰撞,即尝试用明文计算后的摘要和目标摘要比对,一致就说明碰撞成功了