我发现这段代码返回给定String的校验和。
public static String getChecksum(String md5) {
int counter = 0;
while (counter != 2) {
try {
java.security.MessageDigest md = java.security.MessageDigest
.getInstance("MD5");
byte[] array = md.digest(md5.getBytes());
StringBuffer sb = new StringBuffer();
for (int i = 0; i < array.length; ++i) {
sb.append(Integer.toHexString((array[i] & 0xFF) | 0x100)
.substring(1, 3));
}
return sb.toString();
} catch (java.security.NoSuchAlgorithmException e) {
continue;
}
}
return null;
}
我现在想做相反的事情 - 即给定校验和,得到原始字符串。这怎么可能?
答案 0 :(得分:1)
你做不到。加密散列函数(或&#34; MessageDigest
&#34;)的要点是它是单向的 - 没有已知的方法来反转散列,除了暴力(你每次散列的地方)可能的密码,看看哪一个给你相同的哈希值。
如果您想要反转该过程,那么您不需要寻找哈希函数。
答案 1 :(得分:0)
散列是一种单向加密函数,它是有目的且有意设计的,因此您永远不会在给定散列的情况下检索明文。
你可以使用词典等来玩游戏来尝试猜测哈希是什么......但是你不能“解密”它。