php openssl base64解密
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了php openssl base64解密相关的知识,希望对你有一定的参考价值。
一、最近有项目接入了第四方支付,第四方支付提供的文档需要两边进行openssl配合私钥、公钥进行RSA加密来双方通信
二、环境说明
1、LAMP、LNMP都可以,我的环境暂时是LAMP
2、php先安装openssl扩展,否则使用函数会报错,具体openssl扩展可以去百度或者参考博客文档
三、代码实现
1、发送加密数据
<?php
//加密
//组成加密数据
$arr = array(
‘name‘ => ‘test‘, //第三方平台的会员账号
‘password‘ => ‘test‘, //第三方平台的会员密码
‘amount‘ => ‘100‘, //转账金额,最低100,为100的整数倍
‘order_sn‘ => ‘123456789abc‘, //数商交易所生成的订单号(第三方平台在处理完毕后需要回传)
‘sign‘ => ‘86e06157205d5155f5fdddcf077604fd‘, //数商交易所生成的sign(第三方平台在处理完毕后需要回传)
);
//先转成json格式的数据
$arr = json_encode($arr);
//根据私钥获取加密字符串
$key = "私钥内容串";
$res = "-----BEGIN PUBLIC KEY-----\n" .
wordwrap($key, 64, "\n", true) .
"\n-----END PUBLIC KEY-----";
openssl_private_encrypt($arr, $data, $res);
//base64编码
$data = base64_encode($data);
//发送POST请求
$to_arr = array(
‘data‘ => $data
);
//POST请求忽略
2、获取加密串解密
<?php
//解密
$data = "第四方返回的data加密串";
$key= "第四方提供的公钥内容串";
$res = "-----BEGIN PUBLIC KEY-----\n" .
wordwrap($pubKey, 64, "\n", true) .
"\n-----END PUBLIC KEY-----";
//解密字符串
$crypto = ‘‘;
foreach (str_split(base64_decode($data), 128) as $chunk) {
openssl_public_decrypt($chunk, $decryptData, $res);//$decryptData为解密后的数据
$crypto .= $decryptData;
}
//解析json数据得到数组
$arr = json_decode($crypto);
//打印结果
var_dump($arr);
本文出自 “12633313” 博客,请务必保留此出处http://12643313.blog.51cto.com/12633313/1968174
以上是关于php openssl base64解密的主要内容,如果未能解决你的问题,请参考以下文章
PHP base64_encode 在URL地址参数编码上使用
在 JavaScript 中解密 OAEP RSA(如 PHP 的 openssl_private_decrypt)