当前位置:首页 > PHP教程 >

PHP SHA256WithRSA签名和验签

发布时间:2025-04-17 18:03:22 作者:佚名 阅读:(49)

最近项目中需要使用SHA256WithRSA签名和验签来处理数据的安全传输,即对数据进行签名后进行验证。这个过程通常涉及使用私钥进行签名,公钥进行验签。在PHP中,可以通过OpenSSL扩展实现这一功能。接下来将为大家介绍如何在PHP中使用SHA256WithRSA签名和验签,确保数据传输的安全性。

PHP SHA256WithRSA签名和验签

1、生成 sha256WithRSA 签名

function getSign($content, $privateKey){
    $privateKey = "-----BEGIN RSA PRIVATE KEY-----\n" .
        wordwrap($privateKey, 64, "\n", true) .
        "\n-----END RSA PRIVATE KEY-----";

    $key = openssl_get_privatekey($privateKey);
    openssl_sign($content, $signature, $key, "SHA256");
    openssl_free_key($key);
    $sign = base64_encode($signature);
    return $sign;
}

2、验证 sha256WithRSA 签名

function verify($content, $sign, $publicKey){
    $publicKey = "-----BEGIN PUBLIC KEY-----\n" .
        wordwrap($publicKey, 64, "\n", true) .
        "\n-----END PUBLIC KEY-----";

    $key = openssl_get_publickey($publicKey);
    $ok = openssl_verify($content,base64_decode($sign), $key, 'SHA256');
    openssl_free_key($key);
    return $ok;
}

3、调用

	getSign(“您要签名的数据”,”签名的钥匙/可以是公钥签名也可以是私钥签名,一般是私钥加密,公钥解密”);
	verify("验证签名的数据", $sign, '公钥')

以上就是云梦编程为大家介绍的关于PHP生成签名和验证签名方法的全部内容了,希望对大家有所帮助,了解更多相关文章请关注云梦编程网!

© 2023 - 云梦编程网 版权所有 鲁ICP备2021017318号-4