12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364 |
- <?php
- /* *
- * 支付宝接口RSA函数
- * 详细:RSA签名、验签、解密
- * 版本:3.3
- * 日期:2012-07-23
- * 说明:
- * 以下代码只是为了方便商户测试而提供的样例代码,商户可以根据自己网站的需要,按照技术文档编写,并非一定要使用该代码。
- * 该代码仅供学习和研究支付宝接口使用,只是提供一个参考。
- */
- /**
- * RSA签名
- * @param $data 待签名数据
- * @param $private_key_path 商户私钥文件路径
- * return 签名结果
- */
- function rsaSign($data, $private_key_path) {
- $priKey = file_get_contents($private_key_path);
- $res = openssl_get_privatekey($priKey);
- openssl_sign($data, $sign, $res);
- openssl_free_key($res);
- //base64编码
- $sign = base64_encode($sign);
- return $sign;
- }
- /**
- * RSA验签
- * @param $data 待签名数据
- * @param $ali_public_key_path 支付宝的公钥文件路径
- * @param $sign 要校对的的签名结果
- * return 验证结果
- */
- function rsaVerify($data, $ali_public_key_path, $sign) {
- $pubKey = file_get_contents($ali_public_key_path);
- $res = openssl_get_publickey($pubKey);
- $result = (bool)openssl_verify($data, base64_decode($sign), $res);
- openssl_free_key($res);
- return $result;
- }
- /**
- * RSA解密
- * @param $content 需要解密的内容,密文
- * @param $private_key_path 商户私钥文件路径
- * return 解密后内容,明文
- */
- function rsaDecrypt($content, $private_key_path) {
- $priKey = file_get_contents($private_key_path);
- $res = openssl_get_privatekey($priKey);
- //用base64将内容还原成二进制
- $content = base64_decode($content);
- //把需要解密的内容,按128位拆开解密
- $result = '';
- for($i = 0; $i < strlen($content)/128; $i++ ) {
- $data = substr($content, $i * 128, 128);
- openssl_private_decrypt($data, $decrypt, $res);
- $result .= $decrypt;
- }
- openssl_free_key($res);
- return $result;
- }
- ?>
|