PHP-OpenSSL HMAC-SHA1摘要与加密的不匹配

我花了6个小时来实现消息签名算法.它根本无法正常工作:

这是生成摘要的PHP代码:

$payload = "thisisanapple";
$signature = hash_hmac("sha1", $payload, "thisisarandomkey");
$data = base64_encode($signature);
// YzExZWRmZDliMjQzNTZjNzhlNmE3ZTdmMDE3ODJjNmMxMmM4ZTllMQ==

这是运行在Node.js服务器上的JS,其作用相同:

var hmac = crypto.createHmac('sha1', "thisisarandomkey");
hmac.update("thisisanapple");
var signature = hmac.digest('base64');
// wR7f2bJDVseOan5/AXgsbBLI6eE=

我不知道这里出了什么问题.我尝试过SHA256,但它们仍然不同.我还使用了由OpenSSL生成的私钥,无论是明文形式还是在base64中,结果仍然相同(不同的密钥).

解决方法:

hash_hmac有四个参数,最后一个指定输出,默认情况下,hash_hmac返回十六进制字符串,而不是原始数据.因此base64_encode在PHP代码片段中对十六进制字符串进行编码.

这将很好地工作:

$payload = "thisisanapple";
$signature = hash_hmac("sha1", $payload, "thisisarandomkey", true);
$data = base64_encode($signature);
// wR7f2bJDVseOan5/AXgsbBLI6eE=
上一篇:Hash算法简介


下一篇:java – HttpClient 4.1.1在使用NTLM进行身份验证时返回401,浏览器工作正常