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)

OpenSSL一行base64输入。读取输入文件时出错

如何使用之前使用 mcrypt 加密的 OpenSSL 解密字符串?

PHP的aes加解密算法

使用 OpenSSL/C++ 和 PHP/Mcrypt 的 AES-128-CBC 加密:仅解密第一个块