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