以下代码改编自这两个来源:
http://qnimate.com/hashing-using-web-cryptography-api/
https://developer.mozilla.org/en-US/docs/Web/API/SubtleCrypto/digest
(function () {
"use strict";
var crypto = window.crypto || window.msCrypto;
if (typeof crypto.subtle === "undefined") {
return;
}
function convertStringToArrayBuffer (str) {
var strLength = str.length, buffer = new ArrayBuffer(strLength), i = 0;
while (i < strLength) {
buffer[i] = str.charCodeAt(i);
i += 1;
}
return buffer;
}
function convertBufferToHex (buffer) {
var data = new DataView(buffer), i = 0,
dataLength = data.byteLength, cData = null,
hexValue = '';
while (i < dataLength) {
cData = data.getUint8(i).toString(16);
if (cData.length < 2) {
cData = '0' + cData;
}
hexValue += cData;
i += 1;
}
return hexValue;
}
function digest (str) {
var buf = convertStringToArrayBuffer(str);
return crypto.subtle.digest("SHA-256", buf).then(function (hash) {
return convertBufferToHex(hash);
});
}
window.sha256 = {
"convertStringToArrayBuffer": convertStringToArrayBuffer,
"convertBufferToHex": convertBufferToHex,
"digest": digest
};
}());
在 Chrome 或 Firefox 控制台中运行时使用sha256.digest("this string").then(function (x) { console.log(x) } );
并sha256.digest("that strong").then(function (x) { console.log(x) } );
生成相同的十六进制字符串。
事实上,任何两个长度相同的字符串都将具有相同的十六进制表示。
我读过的所有内容都说很少有两个等效的哈希值。这意味着我在这里做错了什么。我不知道那是什么东西。