繁体   English   中英

Node.js中的Hash_hmac等价物

[英]Hash_hmac equivalent in Node.js

我的代码在我的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'); 
}; 

但是,我收到以下错误:

我们计算的请求签名与您提供的签名不匹配。 检查您的密钥和签名方法。

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

如果您使用最后一个参数为true移植hash_hmac ,那么来自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(new Buffer(str, 'utf-8')).digest("hex");
  return signed
}

这里的区别在于,当您将最后一个参数留给hash_hmac(或将其设置为不true东西)时,它的行为与PHP 文档中的定义相同:

设置为TRUE时,输出原始二进制数据。 FALSE输出小写的十六进制。

为了使用node.js执行此操作,我们使用digest('hex')如您在代码段中所见。

这里的主要问题是您使用createHash创建哈希,而不是createHmac创建HMAC。

更改createHashcreateHmac ,你应该找到它产生相同的结果。

这是您应该期望的输出:

chris /tmp/hmac $ cat node.js 
var crypto = require('crypto');
var key = 'abcd';
var data = 'wxyz';

function getHash(string){
    var hmac = crypto.createHmac('sha1', key);
    hmac.update(string); 
    return hmac.digest('binary'); 
};

process.stdout.write(getHash(data));

chris /tmp/hmac $ cat php.php 
<?php
$key = "abcd";
$data = "wxyz";
function __getHash($string)
{
    global $key;
    return hash_hmac('sha1', $string, $key, true); 
}

echo utf8_encode(__getHash($data));

chris /tmp/hmac $ node node.js | base64
WsOKw4xgw4jDlFHDl3jDuEPDuCfCmsOFwoDCrsK/w6ka
chris /tmp/hmac $ php php.php | base64
WsOKw4xgw4jDlFHDl3jDuEPDuCfCmsOFwoDCrsK/w6ka

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM