一、最近有项目接入了第四方支付,第四方支付提供的文档需要两边进行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);