在nodejs中给出这段代码:
const crypto = require('crypto');
const message = 'message to sign';
const secret = 'mysecret';
const signature = crypto.createHmac('sha256', secret).update(message).digest('hex');
console.log(signature);
输出为40d4c57eed56968de0f3a22e73ebf8abc6ab4c38bba95fd2c85dd4dc90bf36b9
在答案here的帮助下,我已使用此功能在Google Apps脚本中完全复制了此行为:
//conversion from byte array taken from: https://stackoverflow.com/a/27933459
function makeHmacSignature(macAlg, message, secret) {
return Utilities.computeHmacSignature(macAlg, message, secret).reduce(function(str,chr){
chr = (chr < 0 ? chr + 256 : chr).toString(16);
return str + (chr.length==1?'0':'') + chr;
},'');
}
但是,假设签名稍有改动,这样秘密就是base64编码的字符串,我们期望在base64中使用摘要。在nodejs代码中,更改很简单:
const crypto = require('crypto');
const message = 'message to sign';
const secret = 'mysecret';
const decodedSecret = Buffer(secret, 'base64');
const signature = crypto.createHmac('sha256', decodedSecret).update(message).digest('base64');
console.log(signature);
提供输出bBLhyGY61BPEbPiFKknX1g9eXv9r98uvwwgVy7YMYDY=
我已经尝试了几个小时,我无法弄清楚如何在Google Apps脚本中复制此行为!
答案 0 :(得分:1)
我从未成功地弄清楚如何使用Google Apps Script本机功能完成此操作。
我使用了jsSHA。我粘贴在optimized sha256.js文件中,使用上面的示例数据,使用内联,此测试函数返回正确的输出:
true
答案 1 :(得分:0)
Google Apps脚本实际上具有实用功能。
所以而不是
const signature = crypto.createHmac('sha256', secret).update(message).digest('hex');
你可以这样做:
var byteSignature = Utilities.computeHmacSha256Signature(message, secret);
// convert byte array to hex string
var signature = byteSignature.reduce(function(str,chr){
chr = (chr < 0 ? chr + 256 : chr).toString(16);
return str + (chr.length==1?'0':'') + chr;
},'');