thinkphp5实现微信扫码支付
来源:本站原创|时间:2020-01-11|栏目:PHP编程|点击: 次
本文实例为大家分享了thinkphp5微信扫码支付的具体代码,供大家参考,具体内容如下
配置WxPay.Config.php
控制器
//微信支付 //参数 订单 价格 public function wxPay($order_number,$money) { header("Content-type:text/html;charset=utf-8"); //require_once VENDOR_PATH.'/alipaymobile/config.php'; require_once VENDOR_PATH.'/wxpay/WxPay.Api.php';//引入微信支付 require_once VENDOR_PATH.'/wxpay/WxPay.Notify.php'; require_once VENDOR_PATH.'/wxpay/phpqrcode/phpqrcode.php'; $input = new \WxPayUnifiedOrder();//统一下单 $config = new \WxPayConfig();//配置参数 $notify = new \QRcode(); //$paymoney = input('post.paymoney'); //支付金额 $paymoney = $money; //测试写死 //$paymoney = 0.01; //测试写死 //$str = date('Ymd').substr(implode(NULL, array_map('ord', str_split(substr(uniqid(), 7, 13), 1))), 0, 8);//生成订单号 $out_trade_no = $order_number; //商户订单号(自定义) $goods_name = '扫码支付'.$paymoney.'元'; //商品名称(自定义) $input->SetBody($goods_name); $input->SetAttach($goods_name); $input->SetOut_trade_no($out_trade_no); $input->SetTotal_fee($paymoney*100);//金额乘以100 $input->SetTime_start(date("YmdHis")); $input->SetTime_expire(date("YmdHis", time() + 600)); $input->SetGoods_tag("test"); //回调地址 注意能访问 $input->SetNotify_url("http://www.域名.com/index.php/index/index/wxpaynotifyurl"); //回调地址 $input->SetTrade_type("NATIVE"); $input->SetProduct_id('123456789');//商品id $result = \WxPayApi::unifiedOrder($config, $input); if($result['result_code']=='SUCCESS' && $result['return_code']=='SUCCESS') { $url = $result["code_url"]; $this->assign('money',$paymoney); $this->assign('url',$url); $this->assign('num',$out_trade_no); //映射视图 微信二维码需要自己生成 return view("../../../template/wxpay"); }else{ $this->error('参数错误'); } // return view(); }
视图 生成二维码 进行扫描付款
<!doctype html> <html> <head> <meta charset="utf-8"> <title>微信支付页面</title> <style> .wxsm{ width:1200px; margin:0 auto; overflow:hidden;} .wxsmt{ width:100%; height:40px; border-bottom:1px solid #ccc;} .wxsmt h2{ font-size:14px; line-height:40px; color:#232323; font-weight:400; text-align:center;} .wxsmc{ width:100%; overflow:hidden;} .smcr{ overflow:hidden; margin:0 auto; } .smcr h2{ font-size:14px; font-weight:400; line-height:40px; text-align:center;} .smcr h2 span{ font-size:20px; color:#f23535;} .smcrb{ width:100%; overflow:hidden;;} .smm{ width:218px; height:284px; border:1px solid #3cb035; background:#3cb035; margin:0 auto} .smm img{ width:218px; height:218px; background:#fff;} .smm span{ display:block; color:#fff; line-height:66px; text-align:center;} </style> <script src="__TEMP__/js/jquery-1.10.1.min.js"></script> </head> <body> <div class="wxsm"> <div class="wxsmt"> <h2>订单提交成功,请尽快付款</h2> </div> <div class="wxsmc"> <div class="smcr"> <h2>应付金额:<span>{$money}</span>元</h2> <div class="smcrb"> <div class="smm"> <img src="/vendor/wxpay/qrcode.php?data=<?php echo urlencode($url);?>"/> <span>打开微信,扫描二维码支付</span> </div> </div> </div> </div> </div> <script> //设置每隔1000毫秒执行一次load() 方法 var myIntval=setInterval(function(){loads()},1000); function loads(){ var xmlhttp; // 轮询的浏览器设置 if (window.XMLHttpRequest){ // code for IE7+, Firefox, Chrome, Opera, Safari xmlhttp=new XMLHttpRequest(); }else{ // code for IE6, IE5 xmlhttp=new ActiveXObject("Microsoft.XMLHTTP"); } xmlhttp.onreadystatechange=function(){ if (xmlhttp.readyState==4 && xmlhttp.status==200){ trade_state=JSON.parse(xmlhttp.responseText); console.log(trade_state);//打印查看轮询的状态,也可以关闭。 //判断订单支付状态 并用document.getElementById方法赋值到myDiv中; if(trade_state.code=='SUCCESS'){ //延迟3000毫秒执行tz() 方法 clearInterval(myIntval); //进行跳转。 var url = "{:url('index/center')}"; var http = window.location.protocol; var zhu = window.location.host; setTimeout("location.href='"+http+"//"+zhu+""+url+"'",1500); }else if(trade_state.code=='REFUND'){ clearInterval(myIntval); }else if(trade_state.code=='NOTPAY'){ }else if(trade_state.code=='CLOSED'){ clearInterval(myIntval); }else if(trade_state.code=='REVOKED'){ clearInterval(myIntval); }else if(trade_state.code=='USERPAYING'){ }else if(trade_state.code=='PAYERROR'){ clearInterval(myIntval); } } } //orderquery.php 文件返回订单状态,通过订单状态确定支付状态 xmlhttp.open("POST","/vendor/wxpay/orderquery.php",false); //下面这句话必须有 //把标签/值对添加到要发送的头文件。 xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded"); xmlhttp.send("out_trade_no=<?php echo $num;?>"); } </script> </body> </html>
支付回调
public function wxpaynotifyurl() { //$xml = $GLOBALS['HTTP_RAW_POST_DATA']; //返回的xml $xml = file_get_contents("php://input"); //$results = db('fund') -> where('id',1) -> update(['a'=>$xml]);exit(); $xmlArr = $this->Init($xml); file_put_contents(dirname(__FILE__).'/xml.txt',$xml); //记录日志 支付成功后查看xml.txt文件是否有内容 如果有xml格式文件说明回调成功 $out_trade_no=$xmlArr['out_trade_no']; //订单号 $total_fee=$xmlArr['total_fee']/100; //回调回来的xml文件中金额是以分为单位的 $result_code=$xmlArr['result_code']; //状态 //$result = db('order') -> where(['order' => $out_trade_no]) -> find(); //if($result['price'] == $total_fee){ if($result_code=='SUCCESS'){ //数据库操作 //处理数据库操作 例如修改订单状态 给账户充值等等 echo 'SUCCESS'; //返回成功给微信端 一定要带上不然微信会一直回调8次 exit; }else{ //失败 return false; exit; } } public function Init($xml) { $array_data = json_decode(json_encode(simplexml_load_string($xml, 'SimpleXMLElement', LIBXML_NOCDATA)), true); return $array_data; }
简单的写了一下 能实现简单的thinkphp5+微信扫码支付的大体流程 若有有问题的地方 还请各位大神指点
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。
您可能感兴趣的文章
- 01-11PHP 进程池与轮询调度算法实现多任务的示例代码
- 01-11php 实现简单的登录功能示例【基于thinkPHP框架】
- 01-11Laravel 微信小程序后端搭建步骤详解
- 01-11Laravel 微信小程序后端实现用户登录的示例代码
- 01-11PHP连续签到功能实现方法详解
- 01-11PHP实现发送微博消息功能完整示例
- 01-11PHP实现提取多维数组指定一列的方法总结
- 01-11php实现快速对二维数组某一列进行组装的方法小结
- 01-11PHP实现二维数组(或多维数组)转换成一维数组的常见方法总结
- 01-11laravel5.1框架下的批量赋值实现方法分析
阅读排行
本栏相关
- 04-02php本站才可以请求数据 php本地数据库
- 04-02关于txt数据库php的信息
- 04-02php打印请求数据 php打印输出结果
- 04-02网页里php操作数据库 php网页例子
- 04-02php插入数据库为乱码 php连接数据库乱
- 04-02php数据库地址 phpstudy 数据库
- 04-02php数据库数据相加 php数据库添加数据
- 04-02数据权限架构思路php 数据权限设计方
- 04-02php数据库输入变量 php里输出数据库数
- 04-02php如何用导入数据 php用来导入其他文
随机阅读
- 08-05DEDE织梦data目录下的sessions文件夹有什
- 04-02jquery与jsp,用jquery
- 01-10delphi制作wav文件的方法
- 08-05dedecms(织梦)副栏目数量限制代码修改
- 01-11Mac OSX 打开原生自带读写NTFS功能(图文
- 01-10C#中split用法实例总结
- 01-11ajax实现页面的局部加载
- 01-10SublimeText编译C开发环境设置
- 01-10使用C语言求解扑克牌的顺子及n个骰子
- 08-05织梦dedecms什么时候用栏目交叉功能?