PHP RSA 私钥加密签名与公钥解密 (SHA256with RSA)

	   $data = [
            'agentId' => $agentid,
            'date' => $time,
        ]; //需要加密的数据,有些是需要数组,有些是拼接,看实际情况

        $enData = json_encode($data);  //有些情况不需要转json
		//$agent_key 密钥生成后的中间部分,下面有拼接头部和尾部,注意下面的$file不要改变格式
        $file = '-----BEGIN RSA PRIVATE KEY-----
' . $agent_key . '
-----END RSA PRIVATE KEY-----
';

        $private_key = openssl_pkey_get_private($file);
        if (!$private_key) {
            return '密钥不正确';
        }
        openssl_sign($enData, $signature, $private_key, 'sha256');
        openssl_free_key($private_key);  //释放密钥资源
        $sign = base64_encode($signature);  //加密的签名
        $url = 'http://****.com/down' . $agentid . '/' . $time . '?sign_data=';
        $url .= urlencode($sign); //签名如果是在url里则需要 签名url化
	//然后根据情况事下载还是请求



	//加密数据解密   $public_key 为公钥,这里就不赋值了,$decrypted为解密数据,直接返回$decrypted
	$data = base64_decode($sign_data);
	openssl_public_decrypt($data,$decrypted,$public_key);


	//公钥加密私钥解密与上面类似
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值