SHA-256哈希返回不同的结果

时间:2016-01-26 02:43:39

标签: java

我们需要使用SHA-256来散列字符串。

这是我的代码:

public String getSHA256HashedString(String clearString) {
    String _LOC = "[SB_UtilityBean: getSHA256HashedString]";

    try {
        MessageDigest md = MessageDigest.getInstance("SHA-256");
        md.update(clearString.getBytes());

        String _encrypted = bytesToHex(md.digest());
        System.out.println(_LOC + "1.0 " + " Result 1: " + _encrypted);
        System.out.println(_LOC + "1.0 " + " Result 2: " + bytesToHex(md.digest()));

        return _encrypted;
    } catch (NoSuchAlgorithmException e) {
        e.printStackTrace();
    }
}

private static String bytesToHex(byte[] bytes) {
    String _LOC = "[SB_UtilityBean: bytesToHex]";

    StringBuffer result = new StringBuffer();
    for (byte byt : bytes) result.append(Integer.toString((byt & 0xff) + 0x100, 16).substring(1));

    return result.toString();
}

如果将bytesToHex(md.digest())分配给变量_encrypted并执行_encrypted的打印行,我会得到结果1:

  

9f86d081884c7d659a2feaa0c55ad015a3bf4f1b2b0b822cd15d6c15b0f00a08

如果我打印bytesToHex(md.digest())的打印行,我会得到结果2:

  

e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855

1 个答案:

答案 0 :(得分:6)

这是预期的。 documentation说(强调我的):

  

public byte[] digest()

     

通过执行填充等最终操作来完成哈希计算。 完成此次通话后,摘要会重置。

因此,对digest()的第二次调用是获取无字节的散列,而不是输入字符串。您必须再次输入字符串,或使用存储的结果。