如果您需要原始字节,则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
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)