本文实例为大家分享了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+微信扫码支付的大体流程 若有有问题的地方 还请各位大神指点
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍微信扫码支付(PC端),包括了微信扫码支付(PC端)的使用技巧和注意事项,需要的朋友参考一下 这里的扫码支付指的是PC网站上面使用微信支付,也就是官方的模式二,网站是Asp.net MVC,整理如下。(demo在最下方) 一、准备工作 使用的微信API中的统一下单方法,关键的参数是‘公众账号ID(appid)',‘商户号(mch_id)'和'商户支付密钥(KEY)‘,所以首先要有一个
本文向大家介绍基于C#实现微信支付宝扫码支付功能,包括了基于C#实现微信支付宝扫码支付功能的使用技巧和注意事项,需要的朋友参考一下 为公司系统业务需要,这几天了解了一下微信和支付宝扫码支付的接口,并用c#实现了微信和支付宝扫码支付的功能。 微信支付分为6种支付模式:1.付款码支付,2.native支付,3.jsapi支付,4.app支付,5.h5支付,6.小程序支付 我在这里用到的是native支
本文向大家介绍微信、支付宝二码合一扫码支付实现思路(java),包括了微信、支付宝二码合一扫码支付实现思路(java)的使用技巧和注意事项,需要的朋友参考一下 一、支付二维码(预订单) 根据需要购买的信息创建预订单,将订单信息保存到Redis中,并设置有效期,注意生产二维码的链接后的参数可以关联到Redis中的key; QRCode 为servlet扫码请求的URL; UUIDUtils.get
本文向大家介绍js微信支付实现代码,包括了js微信支付实现代码的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了js微信支付的具体代码,供大家参考,具体内容如下 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。
本文向大家介绍java微信扫码支付模式一线下支付功能实现,包括了java微信扫码支付模式一线下支付功能实现的使用技巧和注意事项,需要的朋友参考一下 一、准备工作 无数人来追问模式一的开发,所以在这就贴出来,仅供参考。关于模式一和模式二的区别,我有解释过很多次,无非就是模式一的二维码是针对商品的,模式二的二维码是针对订单的,其他具体细节我就不费口舌了,各位可以自行去官方查看文档,然后是选模式一还是模
本文向大家介绍Java SpringMVC实现PC端网页微信扫码支付(完整版),包括了Java SpringMVC实现PC端网页微信扫码支付(完整版)的使用技巧和注意事项,需要的朋友参考一下 一:前期微信支付扫盲知识 前提条件是已经有申请了微信支付功能的公众号,然后我们需要得到公众号APPID和微信商户号,这个分别在微信公众号和微信支付商家平台上面可以发现。其实在你申请成功支付功能之后,微信会通过