如何在JS中获取CryptoJS.HmacSHA256的摘要表示

如何在JS中获取CryptoJS.HmacSHA256的摘要表示,第1张

如何在JS中获取CryptoJS.HmacSHA256的摘要表示

如果您需要原始字节,则CryptoJS似乎不为其提供代码。提到这是因为缺乏针对

Uint8Array
和朋友的跨浏览器兼容性。

但是,在搜索之后,我确实找到了Vincenzo Ciancia创建的一些转换代码:

CryptoJS.enc.u8array = {        stringify: function (wordArray) {        // Shortcuts        var words = wordArray.words;        var sigBytes = wordArray.sigBytes;        // Convert        var u8 = new Uint8Array(sigBytes);        for (var i = 0; i < sigBytes; i++) { var byte = (words[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff; u8[i]=byte;        }        return u8;    },        parse: function (u8arr) {        // Shortcut        var len = u8arr.length;        // Convert        var words = [];        for (var i = 0; i < len; i++) { words[i >>> 2] |= (u8arr[i] & 0xff) << (24 - (i % 4) * 8);        }        return CryptoJS.lib.WordArray.create(words, len);    }};

当然,请注意字节不会直接转换为字符。 您不能使用文本比较 来与

')�kb��>�y+������:�o��H� '
python生成 的内容进行
比较。为此,您 确实
需要一个编码器,例如十六进制或以64为基数。在这种情况下,请改用Artjom的答案。

您不能简单地将字节发送到Javascript。您需要将其转换为文本表示形式,以使其具有可比性。python的hmac模块和CryptoJS都支持十六进制编码。

CryptoJS:

CryptoJS.HmacSHA256("test", "secret").toString(CryptoJS.enc.Hex)

python:

hmac.new("secret", "test", hashlib.sha256).hexdigest()

注意参数顺序的差异。

两者都产生

0329a06b62cd16b33eb6792be8c60b158d89a2ee3a876fce9a881ebb488c0914


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5646934.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-16
下一篇 2022-12-16

发表评论

登录后才能评论

评论列表(0条)

保存