PHP微信支付实例解析_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>";
 }
 }
?>

微信支付源码下载

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

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索thinkphp微信支付
, php微信支付接口
php微信支付demo
php 微信支付实例、php支付宝接口实例、微信支付实例、微信公众号支付实例、微信支付请求实例,以便于您获取更多的相关知识。

时间: 2024-09-20 14:17:17

PHP微信支付实例解析_php实例的相关文章

thinkphp整合微信支付代码分享_php实例

本文实例为大家分享了thinkphp整合微信支付代码,供大家参考,具体内容如下 下载:支付SDK   将微信支付SDK放在第三方类库Vendor下面,请切记把WxPay.Config.php里面的商户信息修改为您的公众号信息,以避免造成资金的流失. php端代码 public function pay(){ //商户基本信息,可以写死在WxPay.Config.php里面,其他详细参考WxPayConfig.php vendor('Pay.JSAPI'); $tools = new \JsApi

ThinkPHP的MVC开发机制实例解析_php实例

ThinkPHP是目前国内应用非常广泛的一款MVC开发框架.本文就以实例形式解析ThinkPHP的MVC开发机制.相信会给大家一定的启发作用.具体分析如下: 一.概述: MVC框架解析如下: M  Model层    模型:就是数据库操作类(通过数据库操作类去操作各个表)         V  View层     视图:指模版.       C  Control层  控制器:就是通过控制器来实现模版,模型之间的控制关系. 二.实例分析: 1.ACTION 控制器: 位置 D:\www\aoli\

php metaphone()函数及php localeconv() 函数实例解析_php实例

php metaphone() 函数计算字符串的 metaphone 键,本文章向码农们介绍 php metaphone() 函数的基本用法和实例,需要的码农可以参考一下本文章的方法和实例. 定义和用法 metaphone() 函数计算字符串的 metaphone 键. metaphone 键代表字符串的英语发音. metaphone() 函数可用于拼写检查程序. 注释:metaphone() 函数为发音相似的单词创建相同的键. 注释:所生成的 metaphone 键长度可变. 提示:metap

微信支付开发教程(一)微信支付URL配置_php实例

一.选择支付类型 目前有两种支付类型     JS API网页支付    Native原生支付 如果没有特殊要求,两种都勾选. 二.支付授权目录 目前可以选择http还是https协议,没有特别要求,选择http.对安全要求比较高的企业,请选择https. 支付授权目录填写自己公司的域名加上目录,目录可以是不存在的目录,例如wxpay. 一个完整的目录参考如下: http://www.demo.com/wxpay/ 蓝色部分表示要选择的. 红色部分表示要填写的,注意最后要有/ 三.共享收货地址

yii实现创建验证码实例解析_php实例

本文以实例形式讲述了yii创建验证码的方法,具体步骤如下所示: 一.在SiteController action()下添加如下代码: return array( // captcha action renders the CAPTCHA image displayed on the contact page 'captcha'=>array( 'class'=>'CCaptchaAction', 'backColor'=>0xFFFFFF, ), // page action rende

Thinkphp3.2.3分页使用实例解析_php实例

首先要搞清楚的就是ThinkPHP3.2.3的分页类已经被移到了Think\Page.class.php,这是跟以前的版本有些不一样的,使用起来还是跟以前版本差不多,但是默认的效果不敢恭维,所以最好是自己加些样式.  我加了一些样式(不怎么好看),大家可以自行的再去改进分页样式,效果图:  在这里我有先把page的设置做成了一个函数getpage,将这个方法放到Application\Common\Common\function.php(注意function不是类)中方便其他地方调用,代码如下:

微信支付开发告警通知实例_php实例

一.告警通知 为了及时通知商户异常,提高商户在微信平台的服务质量.微信后台会向商户推送告警通知,包括发货延迟.调用失败.通知失败等情况,通知的地址是商户在申请支付时填写的告警通知URL,在"公众平台-服务-服务中心-商户功能-商户基本资料-告警通知URL"可以查看.商户接收到告警通知后需要尽快修复其中提到的问题,以免影响线上经营. 告警通知URL接收的postData中还将含xml数据,格式如下: <xml> <AppId><![CDATA[wxf8b4f

微信支付开发发货通知实例_php实例

一.发货通知 为了更好地跟踪订单的情况,需要第三方在收到最终支付通知之后,调用发货通知API告知微信后台该订单的发货状态. 发货时间限制:虚拟.服务类24小时内,实物类72小时内. 请在收到支付通知后,按时发货,并使用发货通知接口将相关信息同步到微信后台.若平台在规定时间内没有收到,将视作发货超时处理. 发货通知API的URL为: https://api.weixin.qq.com/pay/delivernotify?access_token=xxxxxx URL中的参数只包含目前微信公众平台凭

微信支付开发订单查询实例_php实例

因为某一方技术的原因,可能导致商户在预期时间内都收不到最终支付通知,此时商户可以通过该API来查询订单的详细支付状态. 订单查询API的URL为: https://api.weixin.qq.com/pay/orderquery?access_token=xxxxxx URL中的参数只包含目前微信公众平台凭证access_token,而订单查询的真正数据是放在PostData中的,格式如下: {     "appid" : "wwwwb4f85f3a797777",