Как получить HMAC с помощью Crypto Web API
Как я могу получить HMAC-SHA512(ключ, данные) в браузере, используя Crypto Web API (window.crypto
)?
В настоящее время я использую библиотеку CryptoJS, и это довольно просто:
CryptoJS.HmacSHA512("myawesomedata", "mysecretkey").toString();
Результат 91c14b8d3bcd48be0488bfb8d96d52db6e5f07e5fc677ced2c12916dc87580961f422f9543c786eebfb5797bc3febf796b929efac5c83b4ec69228927f21a03a
,
Я хочу избавиться от лишних зависимостей и начать использовать Crypto Web API вместо этого. Как я могу получить тот же результат с ним?
3 ответа
Отвечая на мой собственный вопрос. Код ниже возвращает тот же результат, что и CryptoJS.HmacSHA512("myawesomedata", "mysecretkey").toString();
Повсюду есть обещания, так как WebCrypto является асинхронным:
// encoder to convert string to Uint8Array
var enc = new TextEncoder("utf-8");
window.crypto.subtle.importKey(
"raw", // raw format of the key - should be Uint8Array
enc.encode("mysecretkey"),
{ // algorithm details
name: "HMAC",
hash: {name: "SHA-512"}
},
false, // export = false
["sign", "verify"] // what this key can do
).then( key => {
window.crypto.subtle.sign(
"HMAC",
key,
enc.encode("myawesomedata")
).then(signature => {
var b = new Uint8Array(signature);
var str = Array.prototype.map.call(b, x => ('00'+x.toString(16)).slice(-2)).join("")
console.log(str);
});
});
Async / Await Crypto Subtle HMAC SHA-256/512 с дайджестом Base64
Ниже приводится копия ответа ✅. На этот раз мы используем
async/await
для чистого синтаксиса. Этот подход также предлагает дайджест кодировки base64.
-
secret
- это секретный ключ, который будет использоваться для подписи. -
body
это строка для знака. -
enc
- текстовый кодировщик, преобразующий байтовые массивы UTF-8 в JavaScript. -
algorithm
- это объект JS, который используется для идентификации методов подписи. -
key
это CryptoKey . -
signature
- хеш байтового массива. -
digest
это подпись в кодировке base64.
Код JavaScript следующий:
Исходный ответ на этой странице был полезен при отладке ранее сегодня. Мы используем его, чтобы помочь идентифицировать ошибку в нашей документации по созданию подписей для предоставления токенов доступа для использования API с разрешениями на чтение / запись .
Почему-то ответ @StephenBlum у меня не работает.
Вместо этого я переписываю ответ @StepanSnigirev как асинхронный ниже.