HMAC-SHA256签名计算算法

我正在尝试使用HMAC-SHA256算法创建签名,这是我的代码。我正在使用美国ASCII编码。

final Charset asciiCs = Charset.forName("US-ASCII");

final Mac sha256_HMAC = Mac.getInstance("HmacSHA256");

final SecretKeySpec secret_key = new javax.crypto.spec.SecretKeySpec(asciiCs.encode("key").array(), "HmacSHA256");

final byte[] mac_data = sha256_HMAC.doFinal(asciiCs.encode("The quick brown fox jumps over the lazy dog").array());

String result = "";

for (final byte element : mac_data)

{

result += Integer.toString((element & 0xff) + 0x100, 16).substring(1);

}

System.out.println("Result:[" + result + "]");

我从上面的代码中得到的结果是:

f7bc83f430538424b13298e6aa6fb143ef4d59a14946175997479dbc2d1a3cd8

这与Wiki中显示的相同

HMAC_SHA256("key", "The quick brown fox jumps over the lazy dog") = 0x f7bc83f430538424b13298e6aa6fb143ef4d59a14946175997479dbc2d1a3cd8

除外0x

如果我做对了所有事情,或者可能可以改善我的代码,我正在寻找想法/意见。

回答:

0x仅表示其后的字符表示一个十六进制字符串。

0x1A == 1Ah == 26 == 1A

因此,0x只是为了阐明输出的格式,而无需担心它。

以上是 HMAC-SHA256签名计算算法 的全部内容, 来源链接: utcz.com/qa/434830.html

回到顶部