PHP RSA2 签名算法

PHP-RSA2签名验证

RSA2 是在原来SHA1WithRSA签名算法的基础上,
新增了支持SHA256WithRSA的签名算法。
该算法比SHA1WithRSA有更强的安全能力。

<?php
/**
 * RSA2 加密
 */
class Rsa2
{
    private static $PRIVATE_KEY = <<<EOD
-----BEGIN RSA PRIVATE KEY-----

-----END RSA PRIVATE KEY-----
EOD;

    private static $PUBLIC_KEY  = <<<EOD
-----BEGIN PUBLIC KEY-----
\\\\\\\\
-----END PUBLIC KEY-----
EOD;

    /**
     * 获取私钥
     * @return bool|resource
     */
    public static function getPrivateKey()
    {
        $privKey = self::$PRIVATE_KEY;
        return openssl_pkey_get_private($privKey);
    }

    /**
     * 获取公钥
     * @return bool|resource
     */
    public static function getPublicKey()
    {
        $publicKey = self::$PUBLIC_KEY;
        return openssl_pkey_get_public($publicKey);
    }

    /**
     * 设置私钥
     *
     * @var $private_key 私钥
     *
     * @return void
     */
    public static function setPrivateKey($private_key) : void
    {
        self::$PRIVATE_KEY = $private_key;
        return;
    }

    /**
     * 设置公钥
     *
     * @var $public_key 公钥
     *
     * @return void
     */
    public static function setPublicKey($public_key) : void
    {
        self::$PUBLIC_KEY = $public_key;
        return;
    }

    /**
     * 创建签名
     * @param string $data 数据
     * @return null|string
     */
    public static function createSign($data = '')
    {
        if (!is_string($data)) {
            return null;
        }
        return openssl_sign(
            $data,
            $sign,
            self::getPrivateKey(),
            OPENSSL_ALGO_SHA256
        ) ? urlencode(base64_encode($sign)) : null;
    }

    /**
     * 验证签名
     * @param string $data 数据
     * @param string $sign 签名
     * @return bool
     */
    public static function verifySign($data = '', $sign = '') : bool
    {
        if (!is_string($data) || !is_string($sign)) {
            return false;
        }
        return (bool)openssl_verify(
            $data,
            base64_decode(urldecode($sign)),
            self::getPublicKey(),
            OPENSSL_ALGO_SHA256
        );
    }
}

调用

RSA2::setPublicKey($_rsaInfo['rsa_public_key']);
RSA2::setPrivateKey($_rsaInfo['rsa_private_key']);
$_sign = Rsa2::createSign($_data);
Rsa2::verifySign(http_build_query($_data),$_sign);

在源转载代码基础上做了点微调,以下是源文章:
转载来源:创 PHP RSA2 签名算法

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值