0

我发现这段代码返回给定字符串的校验和。

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;
}

我现在想做相反的事情——即给定校验和,取回原始字符串。这怎么可能?

4

2 回答 2

1

你不能。加密散列函数(或“ MessageDigest”)的要点是它是单向的 - 除了蛮力(你散列每个可能的密码,看看哪个给你相同的密码)之外,没有已知的方法可以反转散列哈希)。

如果您想反转该过程,那么您不是在寻找哈希函数。

于 2015-02-03T21:03:37.530 回答
0

散列是一种单向加密函数,它经过精心设计,使您永远无法检索给定散列的明文。

您可以使用字典等玩游戏来尝试猜测哈希是什么……但您不能“解密”它。

于 2015-02-03T21:03:12.397 回答