PHP微信支付实例解析

前端技术 2023/09/07 PHP

本文为大家分享了PHP微信支付实例,包括PHP微信支付源码,PHP微信退款源码,php微信支付接口,供大家参考,具体内容如下

1.JSapi支付demo(在微信客户端中点击)

<?php
/**
 * JS_API支付demo
 * ====================================================
 * 在微信浏览器里面打开H5网页中执行JS调起支付。接口输入输出数据格式为JSON。
 * 成功调起支付需要三个步骤:
 * 步骤1:网页授权获取用户openid
 * 步骤2:使用统一支付接口,获取prepay_id
 * 步骤3:使用jsapi调起支付
*/
 include_once(\"../WxPayPubHelper/WxPayPubHelper.php\");
 
 //使用jsapi接口
 $jsApi = new JsApi_pub();

 //=========步骤1:网页授权获取用户openid============
 //通过code获得openid
 if (!isset($_GET[\'code\']))
 {
 //触发微信返回code码
 $url = $jsApi->createOauthUrlForCode(WxPayConf_pub::JS_API_CALL_URL);
 Header(\"Location: $url\"); 
 }else
 {
 //获取code码,以获取openid
  $code = $_GET[\'code\'];
 $jsApi->setCode($code);
 $openid = $jsApi->getOpenId();
 }
 
 //=========步骤2:使用统一支付接口,获取prepay_id============
 //使用统一支付接口
 $unifiedOrder = new UnifiedOrder_pub();
 
 //设置统一支付接口参数
 //设置必填参数
 //appid已填,商户无需重复填写
 //mch_id已填,商户无需重复填写
 //noncestr已填,商户无需重复填写
 //spbill_create_ip已填,商户无需重复填写
 //sign已填,商户无需重复填写
 $unifiedOrder->setParameter(\"openid\",\"$openid\");//商品描述
 $unifiedOrder->setParameter(\"body\",\"贡献一分钱\");//商品描述
 //自定义订单号,此处仅作举例
 $timeStamp = time();
 $out_trade_no = WxPayConf_pub::APPID.\"$timeStamp\";
 $unifiedOrder->setParameter(\"out_trade_no\",\"$out_trade_no\");//商户订单号 
 $unifiedOrder->setParameter(\"total_fee\",\"1\");//总金额
 $unifiedOrder->setParameter(\"notify_url\",WxPayConf_pub::NOTIFY_URL);//通知地址 
 $unifiedOrder->setParameter(\"trade_type\",\"JSAPI\");//交易类型
 //非必填参数,商户可根据实际情况选填
 //$unifiedOrder->setParameter(\"sub_mch_id\",\"XXXX\");//子商户号 
 //$unifiedOrder->setParameter(\"device_info\",\"XXXX\");//设备号 
 //$unifiedOrder->setParameter(\"attach\",\"XXXX\");//附加数据 
 //$unifiedOrder->setParameter(\"time_start\",\"XXXX\");//交易起始时间
 //$unifiedOrder->setParameter(\"time_expire\",\"XXXX\");//交易结束时间 
 //$unifiedOrder->setParameter(\"goods_tag\",\"XXXX\");//商品标记 
 //$unifiedOrder->setParameter(\"openid\",\"XXXX\");//用户标识
 //$unifiedOrder->setParameter(\"product_id\",\"XXXX\");//商品ID

 $prepay_id = $unifiedOrder->getPrepayId();
 //=========步骤3:使用jsapi调起支付============
 $jsApi->setPrepayId($prepay_id);

 $jsApiParameters = $jsApi->getParameters();
 //echo $jsApiParameters;
?>

2.native支付模式一demo(用微信扫的静态链接二维码)

<?php
/**
 * Native(原生)支付模式一demo
 * ====================================================
 * 模式一:商户按固定格式生成链接二维码,用户扫码后调微信
 * 会将productid和用户openid发送到商户设置的链接上,商户收到
 * 请求生成订单,调用统一支付接口下单提交到微信,微信会返回
 * 给商户prepayid。
 * 本例程对应的二维码由native_call_qrcode.php生成;
 * 本例程对应的响应服务为native_call.php;
 * 需要两者配合使用。
*/
 include_once(\"../WxPayPubHelper/WxPayPubHelper.php\");

 //设置静态链接
 $nativeLink = new NativeLink_pub(); 
 
 //设置静态链接参数
 //设置必填参数
 //appid已填,商户无需重复填写
 //mch_id已填,商户无需重复填写
 //noncestr已填,商户无需重复填写
 //time_stamp已填,商户无需重复填写
 //sign已填,商户无需重复填写
 $product_id = WxPayConf_pub::APPID.\"static\";//自定义商品id
 $nativeLink->setParameter(\"product_id\",\"$product_id\");//商品id
 //获取链接
 $product_url = $nativeLink->getUrl();

 //使用短链接转换接口
 $shortUrl = new ShortUrl_pub();
 //设置必填参数
 //appid已填,商户无需重复填写
 //mch_id已填,商户无需重复填写
 //noncestr已填,商户无需重复填写
 //sign已填,商户无需重复填写
 $shortUrl->setParameter(\"long_url\",\"$product_url\");//URL链接
 //获取短链接
 $codeUrl = $shortUrl->getShortUrl();
 
?>

3.native支付模式二demo(用微信扫的动态链接二维码)

 <?php
/**
 * Native(原生)支付-模式二-demo
 * ====================================================
 * 商户生成订单,先调用统一支付接口获取到code_url,
 * 此URL直接生成二维码,用户扫码后调起支付。
 * 
*/
 include_once(\"../WxPayPubHelper/WxPayPubHelper.php\");

 //使用统一支付接口
 $unifiedOrder = new UnifiedOrder_pub();
 
 //设置统一支付接口参数
 //设置必填参数
 //appid已填,商户无需重复填写
 //mch_id已填,商户无需重复填写
 //noncestr已填,商户无需重复填写
 //spbill_create_ip已填,商户无需重复填写
 //sign已填,商户无需重复填写
 $unifiedOrder->setParameter(\"body\",\"贡献一分钱\");//商品描述
 //自定义订单号,此处仅作举例
 $timeStamp = time();
 $out_trade_no = WxPayConf_pub::APPID.\"$timeStamp\";
 $unifiedOrder->setParameter(\"out_trade_no\",\"$out_trade_no\");//商户订单号 
 $unifiedOrder->setParameter(\"total_fee\",\"1\");//总金额
 $unifiedOrder->setParameter(\"notify_url\",WxPayConf_pub::NOTIFY_URL);//通知地址 
 $unifiedOrder->setParameter(\"trade_type\",\"NATIVE\");//交易类型
 //非必填参数,商户可根据实际情况选填
 //$unifiedOrder->setParameter(\"sub_mch_id\",\"XXXX\");//子商户号 
 //$unifiedOrder->setParameter(\"device_info\",\"XXXX\");//设备号 
 //$unifiedOrder->setParameter(\"attach\",\"XXXX\");//附加数据 
 //$unifiedOrder->setParameter(\"time_start\",\"XXXX\");//交易起始时间
 //$unifiedOrder->setParameter(\"time_expire\",\"XXXX\");//交易结束时间 
 //$unifiedOrder->setParameter(\"goods_tag\",\"XXXX\");//商品标记 
 //$unifiedOrder->setParameter(\"openid\",\"XXXX\");//用户标识
 //$unifiedOrder->setParameter(\"product_id\",\"XXXX\");//商品ID
 
 //获取统一支付接口结果
 $unifiedOrderResult = $unifiedOrder->getResult();
 
 //商户根据实际情况设置相应的处理流程
 if ($unifiedOrderResult[\"return_code\"] == \"FAIL\") 
 {
 //商户自行增加处理流程
 echo \"通信出错:\".$unifiedOrderResult[\'return_msg\'].\"<br>\";
 }
 elseif($unifiedOrderResult[\"result_code\"] == \"FAIL\")
 {
 //商户自行增加处理流程
 echo \"错误代码:\".$unifiedOrderResult[\'err_code\'].\"<br>\";
 echo \"错误代码描述:\".$unifiedOrderResult[\'err_code_des\'].\"<br>\";
 }
 elseif($unifiedOrderResult[\"code_url\"] != NULL)
 {
 //从统一支付接口获取到code_url
 $code_url = $unifiedOrderResult[\"code_url\"];
 //商户自行增加处理流程
 //......
 }

?>

4.支付查询接口demo

<?php
/**
 * 订单查询-demo
 * ====================================================
 * 该接口提供所有微信支付订单的查询。
 * 当支付通知处理异常或丢失的情况,商户可以通过该接口查询订单支付状态。
 * 
*/
 include_once(\"../WxPayPubHelper/WxPayPubHelper.php\");
 
 //退款的订单号
 if (!isset($_POST[\"out_trade_no\"]))
 {
 $out_trade_no = \" \";
 }else{
  $out_trade_no = $_POST[\"out_trade_no\"];

 //使用订单查询接口
 $orderQuery = new OrderQuery_pub();
 //设置必填参数
 //appid已填,商户无需重复填写
 //mch_id已填,商户无需重复填写
 //noncestr已填,商户无需重复填写
 //sign已填,商户无需重复填写
 $orderQuery->setParameter(\"out_trade_no\",\"$out_trade_no\");//商户订单号 
 //非必填参数,商户可根据实际情况选填
 //$orderQuery->setParameter(\"sub_mch_id\",\"XXXX\");//子商户号 
 //$orderQuery->setParameter(\"transaction_id\",\"XXXX\");//微信订单号
 
 //获取订单查询结果
 $orderQueryResult = $orderQuery->getResult();
 
 //商户根据实际情况设置相应的处理流程,此处仅作举例
 if ($orderQueryResult[\"return_code\"] == \"FAIL\") {
 echo \"通信出错:\".$orderQueryResult[\'return_msg\'].\"<br>\";
 }
 elseif($orderQueryResult[\"result_code\"] == \"FAIL\"){
 echo \"错误代码:\".$orderQueryResult[\'err_code\'].\"<br>\";
 echo \"错误代码描述:\".$orderQueryResult[\'err_code_des\'].\"<br>\";
 }
 else{
 echo \"交易状态:\".$orderQueryResult[\'trade_state\'].\"<br>\";
 echo \"设备号:\".$orderQueryResult[\'device_info\'].\"<br>\";
 echo \"用户标识:\".$orderQueryResult[\'openid\'].\"<br>\";
 echo \"是否关注公众账号:\".$orderQueryResult[\'is_subscribe\'].\"<br>\";
 echo \"交易类型:\".$orderQueryResult[\'trade_type\'].\"<br>\";
 echo \"付款银行:\".$orderQueryResult[\'bank_type\'].\"<br>\";
 echo \"总金额:\".$orderQueryResult[\'total_fee\'].\"<br>\";
 echo \"现金券金额:\".$orderQueryResult[\'coupon_fee\'].\"<br>\";
 echo \"货币种类:\".$orderQueryResult[\'fee_type\'].\"<br>\";
 echo \"微信支付订单号:\".$orderQueryResult[\'transaction_id\'].\"<br>\";
 echo \"商户订单号:\".$orderQueryResult[\'out_trade_no\'].\"<br>\";
 echo \"商家数据包:\".$orderQueryResult[\'attach\'].\"<br>\";
 echo \"支付完成时间:\".$orderQueryResult[\'time_end\'].\"<br>\";
 } 
 }

 //商户自行增加处理流程
 //......
 
?>

5.对账单接口demo

<?php
/**
 * 对账单接口demo
 * ====================================================
 * 商户可以通过该接口下载历史交易清单。
*/
 include_once(\"../WxPayPubHelper/WxPayPubHelper.php\");

 //对账单日期
 if (!isset($_POST[\"bill_date\"])){
 $bill_date = \"20140814\";
 }
 else{
  $bill_date = $_POST[\"bill_date\"];
 
 //使用对账单接口
 $downloadBill = new DownloadBill_pub();
 //设置对账单接口参数
 //设置必填参数
 //appid已填,商户无需重复填写
 //mch_id已填,商户无需重复填写
 //noncestr已填,商户无需重复填写
 //sign已填,商户无需重复填写
 $downloadBill->setParameter(\"bill_date\",\"$bill_date\");//对账单日期 
 $downloadBill->setParameter(\"bill_type\",\"ALL\");//账单类型 
 //非必填参数,商户可根据实际情况选填
 //$downloadBill->setParameter(\"device_info\",\"XXXX\");//设备号 
 
 //对账单接口结果
 $downloadBillResult = $downloadBill->getResult();
 echo $downloadBillResult[\'return_code\'];
 
 if ($downloadBillResult[\'return_code\'] == \"FAIL\") {
 echo \"通信出错:\".$downloadBillResult[\'return_msg\'];
 }else{
 print_r(\'<pre>\');
 echo \"【对账单详情】\".\"</br>\";
 print_r($downloadBill->response);
 print_r(\'</pre>\');
 }
 }
 
?>

6.退款接口demo

<?php
/**
 * 退款申请接口-demo
 * ====================================================
 * 注意:同一笔单的部分退款需要设置相同的订单号和不同的
 * out_refund_no。一笔退款失败后重新提交,要采用原来的
 * out_refund_no。总退款金额不能超过用户实际支付金额(现
 * 金券金额不能退款)。
*/

 include_once(\"../WxPayPubHelper/WxPayPubHelper.php\");

 //输入需退款的订单号
 if (!isset($_POST[\"out_trade_no\"]) || !isset($_POST[\"refund_fee\"]))
 {
 $out_trade_no = \" \";
 $refund_fee = \"1\";
 }else{
  $out_trade_no = $_POST[\"out_trade_no\"];
  $refund_fee = $_POST[\"refund_fee\"];
 //商户退款单号,商户自定义,此处仅作举例
 $out_refund_no = \"$out_trade_no\".\"$time_stamp\";
 //总金额需与订单号out_trade_no对应,demo中的所有订单的总金额为1分
 $total_fee = \"1\";
 
 //使用退款接口
 $refund = new Refund_pub();
 //设置必填参数
 //appid已填,商户无需重复填写
 //mch_id已填,商户无需重复填写
 //noncestr已填,商户无需重复填写
 //sign已填,商户无需重复填写
 $refund->setParameter(\"out_trade_no\",\"$out_trade_no\");//商户订单号
 $refund->setParameter(\"out_refund_no\",\"$out_refund_no\");//商户退款单号
 $refund->setParameter(\"total_fee\",\"$total_fee\");//总金额
 $refund->setParameter(\"refund_fee\",\"$refund_fee\");//退款金额
 $refund->setParameter(\"op_user_id\",WxPayConf_pub::MCHID);//操作员
 //非必填参数,商户可根据实际情况选填
 //$refund->setParameter(\"sub_mch_id\",\"XXXX\");//子商户号 
 //$refund->setParameter(\"device_info\",\"XXXX\");//设备号 
 //$refund->setParameter(\"transaction_id\",\"XXXX\");//微信订单号
 
 //调用结果
 $refundResult = $refund->getResult();
 
 //商户根据实际情况设置相应的处理流程,此处仅作举例
 if ($refundResult[\"return_code\"] == \"FAIL\") {
 echo \"通信出错:\".$refundResult[\'return_msg\'].\"<br>\";
 }
 else{
 echo \"业务结果:\".$refundResult[\'result_code\'].\"<br>\";
 echo \"错误代码:\".$refundResult[\'err_code\'].\"<br>\";
 echo \"错误代码描述:\".$refundResult[\'err_code_des\'].\"<br>\";
 echo \"公众账号ID:\".$refundResult[\'appid\'].\"<br>\";
 echo \"商户号:\".$refundResult[\'mch_id\'].\"<br>\";
 echo \"子商户号:\".$refundResult[\'sub_mch_id\'].\"<br>\";
 echo \"设备号:\".$refundResult[\'device_info\'].\"<br>\";
 echo \"签名:\".$refundResult[\'sign\'].\"<br>\";
 echo \"微信订单号:\".$refundResult[\'transaction_id\'].\"<br>\";
 echo \"商户订单号:\".$refundResult[\'out_trade_no\'].\"<br>\";
 echo \"商户退款单号:\".$refundResult[\'out_refund_no\'].\"<br>\";
 echo \"微信退款单号:\".$refundResult[\'refund_idrefund_id\'].\"<br>\";
 echo \"退款渠道:\".$refundResult[\'refund_channel\'].\"<br>\";
 echo \"退款金额:\".$refundResult[\'refund_fee\'].\"<br>\";
 echo \"现金券退款金额:\".$refundResult[\'coupon_refund_fee\'].\"<br>\";
 }
 }
 
?>

7.退款查询接口demo

<?php
/**
 * 退款申请接口-demo
 * ====================================================
 * 
 * 
*/
 include_once(\"../WxPayPubHelper/WxPayPubHelper.php\");

 //要查询的订单号
 if (!isset($_POST[\"out_trade_no\"]))
 {
 $out_trade_no = \" \";
 }else{
  $out_trade_no = $_POST[\"out_trade_no\"];
 
 //使用退款查询接口
 $refundQuery = new RefundQuery_pub();
 //设置必填参数
 //appid已填,商户无需重复填写
 //mch_id已填,商户无需重复填写
 //noncestr已填,商户无需重复填写
 //sign已填,商户无需重复填写
 $refundQuery->setParameter(\"out_trade_no\",\"$out_trade_no\");//商户订单号
 // $refundQuery->setParameter(\"out_refund_no\",\"XXXX\");//商户退款单号
 // $refundQuery->setParameter(\"refund_id\",\"XXXX\");//微信退款单号
 // $refundQuery->setParameter(\"transaction_id\",\"XXXX\");//微信退款单号
 //非必填参数,商户可根据实际情况选填
 //$refundQuery->setParameter(\"sub_mch_id\",\"XXXX\");//子商户号 
 //$refundQuery->setParameter(\"device_info\",\"XXXX\");//设备号 
 
 //退款查询接口结果
 $refundQueryResult = $refundQuery->getResult();
 
 //商户根据实际情况设置相应的处理流程,此处仅作举例
 if ($refundQueryResult[\"return_code\"] == \"FAIL\") {
 echo \"通信出错:\".$refundQueryResult[\'return_msg\'].\"<br>\";
 }
 else{
 echo \"业务结果:\".$refundQueryResult[\'result_code\'].\"<br>\";
 echo \"错误代码:\".$refundQueryResult[\'err_code\'].\"<br>\";
 echo \"错误代码描述:\".$refundQueryResult[\'err_code_des\'].\"<br>\";
 echo \"公众账号ID:\".$refundQueryResult[\'appid\'].\"<br>\";
 echo \"商户号:\".$refundQueryResult[\'mch_id\'].\"<br>\";
 echo \"子商户号:\".$refundQueryResult[\'sub_mch_id\'].\"<br>\";
 echo \"设备号:\".$refundQueryResult[\'device_info\'].\"<br>\";
 echo \"签名:\".$refundQueryResult[\'sign\'].\"<br>\";
 echo \"微信订单号:\".$refundQueryResult[\'transaction_id\'].\"<br>\";
 echo \"商户订单号:\".$refundQueryResult[\'out_trade_no\'].\"<br>\";
 echo \"退款笔数:\".$refundQueryResult[\'refund_count\'].\"<br>\";
 echo \"商户退款单号:\".$refundQueryResult[\'out_refund_no\'].\"<br>\";
 echo \"微信退款单号:\".$refundQueryResult[\'refund_idrefund_id\'].\"<br>\";
 echo \"退款渠道:\".$refundQueryResult[\'refund_channel\'].\"<br>\";
 echo \"退款金额:\".$refundQueryResult[\'refund_fee\'].\"<br>\";
 echo \"现金券退款金额:\".$refundQueryResult[\'coupon_refund_fee\'].\"<br>\";
 echo \"退款状态:\".$refundQueryResult[\'refund_status\'].\"<br>\";
 }
 } 
?>

微信支付源码下载

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持phpstudy。

本文地址:https://www.stayed.cn/item/18753

转载请注明出处。

本站部分内容来源于网络,如侵犯到您的权益,请 联系我

我的博客

人生若只如初见,何事秋风悲画扇。