public static String convertToMD5(String input) throws Exception {
String md5 = null;
if (null == input)
return null;
try {
// Create MessageDigest object for MD5
MessageDigest digest = MessageDigest.getInstance("MD5");
// Update input string in message digest
digest.update(input.getBytes(), 0, input.length());
// Converts message digest value in base 16 (hex)
md5 = new BigInteger(1, digest.digest()).toString(16);
} catch (NoSuchAlgorithmException e) {
throw e;
}
return md5;
}
使用此代码加密字符串 我想将md5加密解码为普通字符串? 你可以帮忙吗?
答案 0 :(得分:1)
md5不是加密算法。这是一个hash function。散列字符串无法解码。原始字符串被"销毁" /哈希永远。
答案 1 :(得分:1)
要添加到@dit的答案,您只有一个选项;例如,比较MD5字符串。 MD5("cat") == MD5("cat")
,无法从"cat"
派生MD5("cat")
,因为正如其解释的那样,它是一个哈希函数。
您可以使用以下内容进行比较:
public static boolean matching(String orig, String compare){
String md5 = null;
try{
MessageDigest md = MessageDigest.getInstance("MD5");
md.update(compare.getBytes());
byte[] digest = md.digest();
md5 = new BigInteger(1, digest()).toString(16);
return md5.equals(orig);
} catch (NoSuchAlgorithmException e) {
return false;
}
return false;
}
然后,您可以致电matching("d077f244def8a70e5ea758bd8352fcd8", "cat");
,这将返回true
,如果matching(MD5("x"), "y")
,则会返回false。