1.3 KiB
1.3 KiB
title, tags, firstSeen, lastUpdated
| title | tags | firstSeen | lastUpdated |
|---|---|---|---|
| hashBrowser | browser,promise,advanced | 2018-01-17T14:09:01+02:00 | 2021-10-13T19:29:39+02:00 |
Creates a hash for a value using the SHA-256 algorithm. Returns a promise.
- Use the SubtleCrypto API to create a hash for the given value.
- Create a new
TextEncoderand use it to encodeval. Pass its value toSubtleCrypto.digest()to generate a digest of the given data. - Use
DataView.prototype.getUint32()to read data from the resolvedArrayBuffer. - Convert the data to it hexadecimal representation using
Number.prototype.toString(16). Add the data to an array usingArray.prototype.push(). - Finally, use
Array.prototype.join()to combine values in the array ofhexesinto a string.
const hashBrowser = val =>
crypto.subtle
.digest('SHA-256', new TextEncoder('utf-8').encode(val))
.then(h => {
let hexes = [],
view = new DataView(h);
for (let i = 0; i < view.byteLength; i += 4)
hexes.push(('00000000' + view.getUint32(i).toString(16)).slice(-8));
return hexes.join('');
});
hashBrowser(
JSON.stringify({ a: 'a', b: [1, 2, 3, 4], foo: { c: 'bar' } })
).then(console.log);
// '04aa106279f5977f59f9067fa9712afc4aedc6f5862a8defc34552d8c7206393'