gpt4 book ai didi

java - 如何使用 PEM 私钥通过 HMAC 对 PHP 中的数据进行签名

转载 作者:行者123 更新时间:2023-12-02 09:03:02 25 4
gpt4 key购买 nike

我看过很多关于如何在 PHP 中创建 HMAC 的帖子,但使用的 secret 始终是一个简单的字符串(例如“ secret ”)。我需要做的是创建一个 HMAC,其 secret 是私钥,例如从包含 PEM 格式私钥的文件加载。我无法找到任何关于这在 PHP 中是否可行(使用 hash_hmac)的信息。

用法

使用私钥的 HmacSHA256 签名是在 Java 中创建的,我想使用从文件加载的相同私钥在 PHP 中重新创建此签名(根据我的理解,使用 hash_hmac 和 sha256 哈希算法)。

澄清一下:在这种情况下,私钥被用作共享 key ,这意味着两方都拥有该 key 。消息验证过程包括发送带有私钥计算的消息的 HMAC,而接收者则使用相同的私钥计算 HMAC 并根据发送的签名进行验证。

代码

Java:

byte[] data = getDataForSignature();
PrivateKey key = getPrivateKey(); // loaded from a file
Mac mac = Mac.getInstance("HmacSHA256");
mac.init(key);
byte[] hmac = mac.doFinal(data);
// compare hmac with received signature bytes

PHP:

$key = openssl_pkey_get_private("private.key");
$sig = hash_hmac("sha256", $data, $key??, true);

私钥示例

-----BEGIN RSA PRIVATE KEY-----
MIICXgIBAAKBgQCSWro05ZKVGxMTCqAyNZRAXp8Gd7wf6vywXRsFckm9MHOAWZL0
SvFAhM6tlCthuPkQb0c+Hx9PWH1+4sW2u3O+VDvjQEB0ZILd79LraBEshK/36Oux
yyw2K+ghk9Yh00nJOzkkonmdZmVxr0AAzw5el2h9yDjlUa1E8BH/1LzBBwIDAQAB
AoGANtwXbHiZh5bMgZi8D9YRqkdNqOj89aHp8loUJOiAR5B/2x64fSYSZLLjniEq
WckyYzyzIdActmtfL07l+ecuLRipsHoHuzjPiiRRnzJQbgBstnB8rHkuN275YSbC
3gE7nyyX0JPEviwqHv++Uig0RCD1ZbrG0SBMKBlGVrFMddECQQDmVguRhRScTJHH
RaXY/zjZtHp0L1dtzzSLM75+ji2UoRy1yK9z+rnE1PM5QC8PQixbwocGwpRIwGQn
hIg1YAM9AkEAoqk+VNbJ9ykoP9r+8o1PrPR1Ff+EIhpTthRyFngHNbNnOFB0D314
+V4wyO+a/gbiIAmvTuOXV/GwOlgnfVDJkwJBAJNHd5QvxPL/3sLNXPN4ljBWP2pl
DwFO2Wkcx/SCEtETh5kQ3mdJbVlXVMJJsQ2PoW923gHLjydJpYDDNJj0cH0CQQCW
8txHOvQ+C9GwQHirenvgExO9EFv8kdXxeNPPCiAWs6AsYGz0Gwpyz/gR4FlDN/wM
ozAu04IVONLDsh8jah9FAkEAsSUvlo7Nh1ITd75kUsStv7Tjxma3SuKViewWCprD
olDNtncfcZC5SrilHAJEabVxGy1fJL3hYvTYfqNkeB1TcA==
-----END RSA PRIVATE KEY-----

最佳答案

通常使用私钥来执行签名生成,这相当于使用对称 key 创建 MAC 的非对称性。

请注意,HMAC key 可以由任何二进制字符串组成,因此原则上可以将 HMAC 与二进制编码的私钥一起使用。也就是说,对 HMAC 使用非对称私钥是没有意义的。只有持有私钥的人才能验证生成的身份验证标签。相比之下,可以使用 key 对中的公钥来验证数字签名。

<小时/>

现在,如果您有一个在 Java 中使用的 secret key ,那么您需要创建相同的(二进制)key PHP 的参数 hash_hmac功能。

关于java - 如何使用 PEM 私钥通过 HMAC 对 PHP 中的数据进行签名,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35314629/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com