thinkphp5实现微信扫码支付
时间:2022-07-27
本文章向大家介绍thinkphp5实现微信扫码支付,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
本文实例为大家分享了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+微信扫码支付的大体流程 若有有问题的地方 还请各位大神指点
以上就是本文的全部内容,希望对大家的学习有所帮助。
- SQL SERVER几种数据迁移/导出导入的实践
- dom4j 使用总结
- 快速对表的某字段赋递增的数值
- SQL SERVER修改函数名引起的问题
- SQL Server安全(1/11):SQL Server安全概述
- SQL Server安全(2/11):身份验证(Authentication)
- SQL Server安全(3/11):主体和安全对象(Principals and Securables)
- 在SQL Server里如何进行页级别的恢复
- 你可能不知道的字符比较中的“秘密”
- c++实现简单计算器
- re模块(正则表达式)
- Python学习——collections系列
- 为stackGan一个工程创建一个虚拟环境,python 2.7 tensorflow0.12-tensorflow 1.01
- linux 普通操作,查看资源使用情况
- php概述
- php教程
- php环境搭建
- PHP书写格式
- php变量
- php常量
- PHP注释
- php数组
- php字符串 string
- PHP整型 integer
- PHP浮点型 float
- php布尔型
- php数据类型之数组
- php数据类型之对象
- php数据类型之null
- php数据类型之间的转换
- php运算符
- php表达式
- PHP循环控制
- PHP流程控制
- php函数
- php全局变量
- PHP魔术变量
- php命名空间
- php 日期
- PHP包含文件
- php文件
- PHP 文件上传
- php Cookies
- php Sessions
- php email
- php安全email
- php错误处理
- PHP异常处理
- php过滤器
- PHP 高级过滤器
- php json
- php 表单
- PHP MySQL 简介
- PHP 连接 MySQL
- php创建数据库
- php 创建表
- php mysq 插入数据
- PHP MySQL 插入多条数据
- PHP MySQL 预处理语句
- php mysql 读取数据
- php mysql where
- PHP MySQL Order By
- PHP MySQL Update
- PHP MySQL Delete
- php ODBC