问题描述
我使用keybase.io API - 尝试从javascript驱动它。登录是一个两步过程。第二步详述为
。
我遇到了以下情况:
我正在使用CryptoJS库,它提供了下面的实现示例
var hash = CryptoJS.HmacSHA256('Message','Secret Passphrase');
我有几个问题;
-
作为术语的问题,'MAC key'等于'Secret Passphrase',因此CryptoJS函数参数的顺序与Keybase上给出的代码示例相反?
/ li>
-
CryptoJS示例具有平滑的ASCII输入,而Keybase上的指令用于提供二进制输入。当我尝试和喂它一个uint8array参数(这是我从使用keybase API的上一步得到的),如下所示:
TypeError:g.clamp不是函数
e,m = 4 * h;
g.sigBytes> m&&(g = f.finalize(g));
g.clamp();
for(var r = this._oKey = g.clone()
此提供了由Vincenzo Ciancia创建的(未测试的)转换器: / p> I am working with the keybase.io API - trying to drive it from javascript. Logging in is a two step process. The second step is detailed athttps://keybase.io/docs/api/1.0/call/login. I am stuck on the following; I am using the CryptoJS library which gives the following example for implementation I have a couple of problems; as a matter of terminology does 'MAC key' equal 'Secret Passphrase' and hence the CryptoJS function parameters are reversed in their order vs the code example given on Keybase? The CryptoJS example has plain ascii inputs whilst the instructions on Keybase are to feed binary inputs. When I try and feed it a uint8array parameter (which is what I get from the previous step in using the keybase API) it keels over as follows; This post provides such an (untested) converter created by Vincenzo Ciancia: 这篇关于在Javascript中实现HMAC-SHA256 for Keybase的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持! CryptoJS.HmacSHA256()
happily拥有自己的 WordArray
作为键,所以你只需要将你的
UInt8Array
转换为CryptoJS' WordArray
p>
CryptoJS.enc.u8array = {
/ **
*将字数组转换为Uint8Array。
*
* @param {WordArray} wordArray字数组。
*
* @return {Uint8Array} Uint8Array。
*
* @static
*
* @example
*
* var u8arr = CryptoJS.enc.u8array.stringify(wordArray);
* /
stringify:function wordArray){
//快捷方式
var words = wordArray.words;
var sigBytes = wordArray.sigBytes;
//转换
var u8 = new Uint8Array(sigBytes);
for(var i = 0; i var byte =(words [i>>> 2]> 4)* 8))& 0xff;
u8 [i] = byte;
}
return u8;
},
/ **
*将Uint8Array转换为字数组。
*
* @param {string} u8Str Uint8Array。
*
* @return {WordArray}字数组。
*
* @static
*
* @example
*
* var wordArray = CryptoJS.enc.u8array.parse(u8arr);
* /
parse:function(u8arr){
//快捷键
var len = u8arr.length;
//转换
var words = [];
for(var i = 0; i words [i>> 2] | =(u8arr [i]& 0xff)< (24-(i%4)* 8);
}
return CryptoJS.lib.WordArray.create(words,len);
}
};
var hash = CryptoJS.HmacSHA256('Message','Secret Passphrase');
TypeError: g.clamp is not a function
e,m=4*h;
g.sigBytes>m&&(g=f.finalize(g));
g.clamp();
for(var r=this._oKey=g.clone()
CryptoJS.HmacSHA256()
happily takes its own WordArray
as a key. So you only need to convert your UInt8Array
to CryptoJS' WordArray
. CryptoJS.enc.u8array = {
/**
* Converts a word array to a Uint8Array.
*
* @param {WordArray} wordArray The word array.
*
* @return {Uint8Array} The Uint8Array.
*
* @static
*
* @example
*
* var u8arr = CryptoJS.enc.u8array.stringify(wordArray);
*/
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;
},
/**
* Converts a Uint8Array to a word array.
*
* @param {string} u8Str The Uint8Array.
*
* @return {WordArray} The word array.
*
* @static
*
* @example
*
* var wordArray = CryptoJS.enc.u8array.parse(u8arr);
*/
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);
}
};