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 に答える