本文实例讲述了ThinkPHP框架整合微信支付之刷卡模式。分享给大家供大家参考,具体如下:
大家好,这篇文章是继微信支付之Native 扫码支付 模式二之后的微信支付系列教程第四篇:微信刷卡支付
本教程跟前三篇教程不一样,所需要的类库也不一样,所以做刷卡支付的时候,与之前的方法没多少关系,大家注意一下。
下面开始介绍详细步骤!
step1:下载微信刷卡支付demo,如下图:
WxPayMicropayHelper:这个文件夹下就是刷卡支付微信提供的类库
demo:这个文件夹下是关于刷卡支付的详细demo
这里我们要用到
micropay_call.php:这个就是刷卡支付的具体demo
我们可以把里面内容复制下来,放到TP的控制器中(稍后介绍)
step2:把下载下来的微信刷卡支付的类库同样放到Vendor目录下:
step3:上面的类库放好后我们可以来写控制器里面的内容了首先还是引入类库:
/** * 初始化 */ public function _initialize() { //引入WxPayPubHelper vendor('WxPayMicropayHelper.WxPayMicropayHelper'); }
接下来把micropay_call.php下的代码提取出来复制到控制器下,并给个名字:
public function micropay() { //自定义订单号,此处仅作举例 $timeStamp = time(); $out_trade_no = \WxPayConf_micropay::APPID."$timeStamp"; //获取用户一维码 if (isset($_POST["auth_code"])) { $auth_code = $_POST["auth_code"]; //使用被扫支付接口 $micropayCall = new \MicropayCall(); //设置被扫支付接口参数 //设置必填参数 //appid已填,商户无需重复填写 //mch_id已填,商户无需重复填写 //noncestr已填,商户无需重复填写 //spbill_create_ip已填,商户无需重复填写 //sign已填,商户无需重复填写 $micropayCall->setParameter("body","贡献一分钱");//商品描述 $micropayCall->setParameter("out_trade_no","$out_trade_no");//商户订单号 $micropayCall->setParameter("total_fee","1");//总金额 $micropayCall->setParameter("auth_code","$auth_code");//交易类型 //非必填参数,商户可根据实际情况选填 //$micropayCall->setParameter("sub_mch_id","XXXX");//子商户号 //$micropayCall->setParameter("device_info","XXXX");//设备号 //$micropayCall->setParameter("attach","XXXX");//附加数据 //$micropayCall->setParameter("time_start","XXXX");//交易起始时间 //$micropayCall->setParameter("time_expire","XXXX");//交易结束时间 //$micropayCall->setParameter("goods_tag","XXXX");//商品标记 //$micropayCall->setParameter("openid","XXXX");//用户标识 //$micropayCall->setParameter("product_id","XXXX");//商品ID //提交订单 $micropayCallResult = $micropayCall->getResult(); //商户根据实际情况设置相应的处理流程,此处仅作举例 if ($micropayCallResult["return_code"] == "FAIL") { echo "通信出错:".$micropayCallResult['return_msg']."
"; } elseif($micropayCallResult["result_code"] == "FAIL") { echo "出错"."
"; echo "错误代码:".$micropayCallResult['err_code']."
"; echo "错误代码描述:".$micropayCallResult['err_code_des']."
"; } else { echo "用户标识:".$micropayCallResult['openid']."
"; echo "是否关注公众账号:".$micropayCallResult['is_subscribe']."
"; echo "交易类型:".$micropayCallResult['trade_type']."
"; echo "付款银行:".$micropayCallResult['bank_type']."
"; echo "总金额:".$micropayCallResult['total_fee']."
"; echo "现金券金额:".$micropayCallResult['coupon_fee']."
"; echo "货币种类:".$micropayCallResult['fee_type']."
"; echo "微信支付订单号:".$micropayCallResult['transaction_id']."
"; echo "商户订单号:".$micropayCallResult['out_trade_no']."
"; echo "商家数据包:".$micropayCallResult['attach']."
"; echo "支付完成时间:".$micropayCallResult['time_end']."
"; } } else { $this->assign('out_trade_no',$out_trade_no); $this->display(); } }
这是我写的控制器方法内容,对应micropay.html页面:
微信安全支付 订单号:
到此我们就可以去测试一下了
请看页面:
面中刷卡的一维码就是你微信里面钱包下面的刷卡功能,打开后就可以看到你的一维码,这个一维码是过一段时间就自己刷新的,输入进去点击提交,请看微信页面:
到此,刷卡支付功能也做好啦
微信支付教程jsapi篇:
//www.jb51.net/article/159351.htm
微信支付教程扫码模式一:
//www.jb51.net/article/159356.htm
微信支付教程扫码模式二:
//www.jb51.net/article/159362.htm
更多关于thinkPHP相关内容感兴趣的读者可查看本站专题:《ThinkPHP入门教程》、《thinkPHP模板操作技巧总结》、《ThinkPHP常用方法总结》、《codeigniter入门教程》、《CI(CodeIgniter)框架进阶教程》、《Zend FrameWork框架入门教程》及《PHP模板技术总结》。
希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。