拉卡拉支付回调验签

这段代码展示了如何使用RSA算法进行签名生成和验证。`genSign`函数通过私钥对字符串进行签名,`getSignStr`函数整理待签名的参数并排序,`verifySign`函数则利用公钥对签名进行解密验证。这些方法常用于确保数据传输过程中的完整性和安全性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

/**
 * 获取私钥加密签名
 *
 * @param $toSign 待签名字符串
 * @param $privateKey 私钥
 * @return string
 */
public static function genSign($toSign, $privateKey)
{
    $privateKey = "-----BEGIN RSA PRIVATE KEY-----\n" .
        wordwrap($privateKey, 64, "\n", true) .
        "\n-----END RSA PRIVATE KEY-----";

    $key = openssl_get_privatekey($privateKey);
    openssl_sign($toSign, $signature, $key);
    openssl_free_key($key);

    $sign = base64_encode($signature);
    return $sign;

}

/**
 * 获取待签名字符
 *
 * @param $data
 * @return string
 */
public static function getSignStr($data)
{
    //按字典序排序参数
    ksort($data);
    $sign = '';
    foreach ($data as $k => $v) {
        $sign .= $k . "=" . $v . "&";
    }
    $sign =  rtrim($sign, '&');
    return $sign;
}

/**
 * 公钥解密签名验证
 *
 * @param $data 待签名字符串
 * @param $sign  签名
 * @param $pubKey 公钥
 * @return bool
 */
public static function verifySign($data, $sign, $pubKey)
{
    $sign = base64_decode($sign);
    $pubKey = "-----BEGIN PUBLIC KEY-----\n" .
        wordwrap($pubKey, 64, "\n", true) .
        "\n-----END PUBLIC KEY-----";
    $key = openssl_pkey_get_public($pubKey);
    $result = openssl_verify($data, $sign, $key, OPENSSL_ALGO_SHA1) === 1;
    return $result;
}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值