public class Md5Util {/** * 根據(jù)輸入的字符串生成固定的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(); } // 使用指定的字節(jié)更新摘要 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類型的字符串?。。。。?
1 回答

心有法竹
TA貢獻1866條經(jīng)驗 獲得超5個贊
首先MD5是不可逆的,他不是密碼,是摘要
有庫函數(shù)可以調(diào)用,自行查找,你要自己寫也是可以的,看一下密碼學,了解下MD5的生成原理就可以了
MD5不能還原成String的,就是說這是不能解密的,唯一可破解的方式是,結(jié)合彩虹表等進行MD5碰撞,即嘗試用明文計算后的摘要和目標摘要比對,一致就說明碰撞成功了
添加回答
舉報
0/150
提交
取消