首页 > 32位MD5码还原成原来的String类型的字符串。代码如下:

32位MD5码还原成原来的String类型的字符串。代码如下:

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碰撞,即尝试用明文计算后的摘要和目标摘要比对,一致就说明碰撞成功了

【热门文章】
【热门文章】