微信小程序JSAPI下单支付PHP前后端教程

准备数据:

微信支付API证书,微信支付商户号,小程序appid,微信支付API证书序列号

获取微信支付api证书教程:如何下载微信支付证书(API证书)_荒~的博客-CSDN博客_微信支付证书

获取微信支付API证书序列号:点击管理证书即可看到

 

第一步:生成预支付交易单

参考文档:微信支付-开发者文档 (qq.com)

按照请求参数的需求创建出一个json数据 

数据示例

这是前端创建的一个请求参数的对象

下面展示PHP后端的文件目录,cert用于上传微信支付API证书

这是cert文件夹内容

开始写PHP端的pay.php文件用于生成签名

参考文档签名生成-接口规则 | 微信支付商户平台文档中心 (qq.com)

下面我们以JSAPI下单接口为例参考文档微信支付-开发者文档 (qq.com)

请求URL:https://api.mch.weixin.qq.com/v3/pay/transactions/jsapi

请求方式:POST

<?php
//微信支付API证书序列号
$serial_no="ABCDEFG";
//你的小程序appid
$appid="123456";
//$body是用于接收前端请求携带的参数
$body=json_decode(file_get_contents("php://input"),true);
//请求接口的请求方式
$http_method=$body['http_method'];
//生成时间戳
$timestamp = time();
//生成随机数
$nonce=randomString(32);
//接收需要给接口发起请求携带的请求体
$data=$body['data'];
//接口url
$url=$body['url'];
$url_parts = parse_url($url);
$canonical_url = ($url_parts['path'] . (!empty($url_parts['query']) ? "?${url_parts['query']}" : ""));
$message = $http_method."\n".
$canonical_url."\n".
$timestamp."\n".
$nonce."\n".
$data."\n";
//获取私钥文件
$mch_private_key = file_get_contents('./cert/apiclient_key.pem');
//生成签名
openssl_sign($message, $raw_sign,$mch_private_key, 'sha256WithRSAEncryption');
$sign =base64_encode($raw_sign);
$token=sprintf('mchid="%s",nonce_str="%s",timestamp="%d",serial_no="%s",signature="%s"',
$appid, $nonce, $timestamp, $serial_no, $sign);
//输出数据
print_r(json_encode(["msg"=>"预订单生成成功","code"=>200,"token"=>$token,"data"=>$data,"timestamp"=>$timestamp,"nonce"=>$nonce]));
// 生成随机字符串函数
function randomString($len = 32)
{
    $string = '';
    $char = 'ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz2345678';
    for ($i = 0; $i < $len; $i++) {
        $string .= $char[mt_rand(0, strlen($char) - 1)];
    }
    return $string;
}
?>

下面是前端对pay.php文件发起请求

请求成功将会得到 timestamp(时间戳),nonce(随机字符串),data(发送给jsapi接口的请求体)

第二步:前端对jsapi下单接口发起请求

请求URL:https://api.mch.weixin.qq.com/v3/pay/transactions/jsapi

请求方式:POST

 请求成功后会返回prepay_id,如果没有返回就说明出错了

第三步:写后端sign.php文件

<?php
//你的小程序appid
$appid="wx123";
//用于接收前端发起请求携带的参数
$body=json_decode(file_get_contents("php://input"),true);
//用户对JSAPI下单接口发起请求后得到的prepay_id
$prepay_id=$body['prepay_id'];
//时间戳
$timestamp =$body['timestamp'];
//随机字符串
$nonce=$body['nonce'];
$message = $appid."\n".
$timestamp."\n".
$nonce."\n".
$prepay_id."\n";
//获取私钥文件
$mch_private_key = file_get_contents('./cert/apiclient_key.pem');
// 生成签名
openssl_sign($message, $raw_sign,$mch_private_key, 'sha256WithRSAEncryption');
$sign = base64_encode($raw_sign);
print_r(json_encode(["msg"=>"签名成功","code"=>200,"sign"=>$sign]));
?>

对sign.php文件发起请求

请求成功后得到sign,最后调用小程序的拉起支付接口

这是paysuccess.php文件用于支付成功的通知地址

 

 

 最后注意:没有对支付做安全处理请自行解决

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值