次のコードは、これら 2 つのソースから改作されました。
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 コンソールで実行すると、同じ 16 進文字列を使用sha256.digest("this string").then(function (x) { console.log(x) } );して生成します。sha256.digest("that strong").then(function (x) { console.log(x) } );
実際、同じ長さの 2 つの文字列は同じ 16 進数表現になります。
私が読んだことはすべて、2 つの同等のハッシュを持つことはまれであると述べています。つまり、ここで何か間違ったことをしているということです。それが何なのか、私にはわかりません。