PHP微信支付实例解析
来源: 阅读:1396 次 日期:2016-08-11 14:42:47
温馨提示: 小编为您整理了“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>";

 }

 } 

?>

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

更多信息请查看网络编程
手机网站地址:PHP微信支付实例解析
由于各方面情况的不断调整与变化, 提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65317125(9:00—18:00) 获取招聘考试信息及咨询关注公众号:hfpxwx
咨询QQ:526150442(9:00—18:00)版权所有:
云南网警报警专用图标
Baidu
map