javascript - Node.js 中的 Hash_hmac 等效项

标签 javascript php node.js amazon-s3 sign

我有在我的 PHP 应用程序中运行的代码。在 PHP 中,我使用以下代码对 url 进行签名:

private static function __getHash($string)
{
    return hash_hmac('sha1', $string, self::$__secretKey, true);    
}

我正在尝试在 Node.js 应用程序中以相同的方式对 URL 进行签名。这就是我正在尝试的:

S3.prototype.getHash = function(string){
    var key = this.secret_key; 
    var hmac = crypto.createHash('sha1', key);
    hmac.update(string); 
    return hmac.digest('binary'); 
}; 

但是,我收到以下错误:

The request signature we calculated does not match the signature you provided. Check your key and signing method.

这些代码段做同样的事情吗?我错过了什么吗?

最佳答案

如果您要移植 hash_hmac 且最后一个参数是 true,那么 Chris 的这个回答很好。在这种情况下,生成二进制文件,就像 Chris 的 javascript 一样。

补充一点,这个例子:

 $sign = hash_hmac('sha512', $post_data, $secret);

将在 nodejs 中移植类似这样的功能:

const crypto = require("crypto");

function signHmacSha512(key, str) {
  let hmac = crypto.createHmac("sha512", key);
  let signed = hmac.update(Buffer.from(str, 'utf-8')).digest("hex");
  return signed
}

这里的区别在于,当您省略 hash_hmac 的最后一个参数(或将其设置为非 true 的值)时,它的行为与 PHP docs 中定义的一样。 :

When set to TRUE, outputs raw binary data. FALSE outputs lowercase hexits.

为了使用 node.js 执行此操作,我们使用 digest('hex'),正如您在代码段中看到的那样。

关于javascript - Node.js 中的 Hash_hmac 等效项,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36924021/

相关文章:

javascript - 为什么即使一切都正确执行,POST 也会返回错误?

javascript - 如何从代码文本加载模块?

javascript - 如何将 dropbox.js 与 OAuth 1 结合使用

php - sql表如何将从sql表中获取的数字数组相乘并存储到数组中并返回

PHP 生成下载文件然后重定向

node.js - Lua从Nodejs获取参数

javascript - 在 JavaScript 中分配变量名称的匿名函数

javascript - 无法连接到 socket.io 两次

php - 使用 ORM 创建嵌套关系并最小化查询

javascript - 如何访问不允许cors的API?