Sar*_*tts 11 javascript php sign amazon-s3 node.js
我的代码在我的PHP应用程序中运行.在PHP中,我使用以下代码对URL进行签名:
private static function __getHash($string)
{
return hash_hmac('sha1', $string, self::$__secretKey, true);
}
Run Code Online (Sandbox Code Playgroud)
我试图在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');
};
Run Code Online (Sandbox Code Playgroud)
但是,我收到以下错误:
我们计算的请求签名与您提供的签名不匹配.检查您的密钥和签名方法.
这些代码片段做同样的事情吗?我错过了什么吗?
如果您hash_hmac使用最后一个参数进行移植,那么Chris的答案很好true.在这种情况下,生成二进制文件,就像Chris的javascript一样.
要添加到该示例,此示例:
$sign = hash_hmac('sha512', $post_data, $secret);
Run Code Online (Sandbox Code Playgroud)
将在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
}
Run Code Online (Sandbox Code Playgroud)
这里的区别在于,当您将最后一个参数留给hash_hmac(或将其设置为不是true)时,它的行为与PHP 文档中的定义相同:
设置为TRUE时,输出原始二进制数据.FALSE输出小写的十六进制.
为了使用node.js执行此操作,我们将使用digest('hex')您在代码段中看到的内容.
这里的主要问题是,您使用的createHash是创建哈希,而不是createHmac创建HMAC。
更改createHash为createHmac,您将发现它产生相同的结果。
这是您应该期望的输出:
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
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
6695 次 |
| 最近记录: |