tp3实现微信公众号支付
管理员 发布于 7年前   393
1.首先拿到APPID,MCHID,KEY,APPSECRET,NOTIFY_URL,然后在WxPayConfig填写;
2.授权目录url直接到支付方法;
3.回调写你自己的回调url;
4.把官方demo下载放在verdor目录 我的放在 http://houtizong.iask.in/tp5blog/index/download/
控制器: //weix支付 public function wxpay() { Vendor('lib.JSSDK'); Vendor('lib.WxPayJsApiPay'); Vendor('lib.log'); Vendor('lib.WxPayApi'); //实例化JSSDK $jssdk=new \JSSDK(C('appid'),C('appSecret')); //获取数据 $signPackage =$jssdk->GetSignPackage(); //初始化日志 $logHandler= new \CLogFileHandler("./logs/".date('Y-m-d').'.log'); $loginfo=\Log::Init($logHandler, 15); //①获取用户openid $tools=new \JsApiPay(); $openId = $tools->GetOpenid(); //②统一下单 $input=new \WxPayUnifiedOrder(); $input->SetBody("公益捐款"); //设置商品或支付单简要描述 $input->SetAttach("附加数据"); //设置附加数据,在查询API和支付通知中原样返回,该字段主要用于商户携带订单的自定义数据 $input->SetOut_trade_no(\WxPayConfig::MCHID.date("YmdHis")); //设置商户系统内部的订单号,32个字符内、可包含字母, 其他说明见商户订单号 $input->SetTotal_fee("1"); //设置订单总金额,只能为整数,详见支付金额 $input->SetTime_start(date("YmdHis")); //设置订单生成时间,格式为yyyyMMddHHmmss,如2009年12月25日9点10分10秒表示为20091225091010。其他详见时间规则 $input->SetTime_expire(date("YmdHis",time()+ 600)); //设置订单失效时间,格式为yyyyMMddHHmmss,如2009年12月27日9点10分10秒表示为20091227091010。其他详见时间规则 $input->SetGoods_tag("商品标记"); //设置商品标记,代金券或立减优惠功能的参数,说明详见代金券或立减优惠 $input->SetNotify_url("xxx/index/wxcall");//设置接收微信支付异步通知回调地址 $input->SetTrade_type("JSAPI"); //设置取值如下:JSAPI,NATIVE,APP,详细说明见参数规定 $input->SetOpenid($openId); //设置trade_type=JSAPI,此参数必传,用户在商户appid下的唯一标识。下单前需要调用【网页授权获取用户信息】接口获取到用户的Openid。 $order = \WxPayApi::unifiedOrder($input); $jsApiParameters=$tools->GetJsApiParameters($order); $this->assign('jsApiParameters',$jsApiParameters); $this->assign('signPackage',$signPackage); $this->display(); } //回调 public function wxcall() { // $xml = $GLOBALS['HTTP_RAW_POST_DATA']; // // 这句file_put_contents是用来查看服务器返回的XML数据 测试完可以删除了 // file_put_contents('./Application/Public/log.txt',$xml,FILE_APPEND); // //将服务器返回的XML数据转化为数组 // //$data = json_decode(json_encode(simplexml_load_string($xml,'SimpleXMLElement',LIBXML_NOCDATA)),true); // $data = xmlToArray($xml); // // 保存微信服务器返回的签名sign // $data_sign = $data['sign']; // // sign不参与签名算法 // unset($data['sign']); // $sign = $this->makeSign($data); // // 判断签名是否正确 判断支付状态 // if ( ($sign===$data_sign) && ($data['return_code']=='SUCCESS') && ($data['result_code']=='SUCCESS') ) { // $result = $data; // // 这句file_put_contents是用来查看服务器返回的XML数据 测试完可以删除了 // file_put_contents('./Application/Public/log1.txt',$xml,FILE_APPEND); // //获取服务器返回的数据 // $order_sn = $data['out_trade_no']; //订单单号 // $order_id = $data['attach']; //附加参数,选择传递订单ID // $openid = $data['openid']; //付款人openID // $total_fee = $data['total_fee']; //付款金额 // //更新数据库 // $this->updateDB($order_id,$order_sn,$openid,$total_fee); // }else{ // $result = false; // } // // 返回状态给微信服务器 // if ($result) { // $str=''; // }else{ // $str=''; // } // echo $str; // return $result; }
<!DOCTYPE html> <html> <script> (function (doc, win) { var docEl = doc.documentElement, resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize', recalc = function () { var clientWidth = docEl.clientWidth; if (!clientWidth) return; if(clientWidth>=640){ docEl.style.fontSize = '100px'; }else{ docEl.style.fontSize = 100 * (clientWidth / 640) + 'px'; } }; if (!doc.addEventListener) return; win.addEventListener(resizeEvt, recalc, false); doc.addEventListener('DOMContentLoaded', recalc, false); })(document, window); </script> <head> <meta charset="utf-8"> <meta name="viewport" content="user-scalable=no, width=device-width, initial-scale=1, maximum-scale=1"> <script src="https://res.wx.qq.com/open/js/jweixin-1.2.0.js" type="text/javascript" charset="utf-8"></script> <title>wxpay</title> </head> <body> <div class="pay" style="margin:0 auto"> <p style="font-size: 20px;">商品名称:侯哥支付</p> <p style="font-size: 20px;">金额大小:1分钱</p> <span id="zhifu" style="margin:0 auto;width:237px;height:72px;border: 1px solid #DECECE;font-size: 20px;padding: 10px;border-radius: 5px;"> 去支付 </span> </div> </body> <script> onload=function() { document.getElementById('zhifu').addEventListener('touchstart',function() { if (typeof WeixinJSBridge == "undefined"){ if( document.addEventListener ){ document.addEventListener('WeixinJSBridgeReady', jsApiCall, false); }else if (document.attachEvent){ document.attachEvent('WeixinJSBridgeReady', jsApiCall); document.attachEvent('onWeixinJSBridgeReady', jsApiCall); } }else{ jsApiCall(); } function jsApiCall() { WeixinJSBridge.invoke( 'getBrandWCPayRequest', {$jsApiParameters}, function(res){ WeixinJSBridge.log(res.err_msg); if(res.err_msg.indexOf('ok')!=-1){ localStorage.clear(); //location.href='{:U('wxpay')}' } } ); } }); } </script> </html>
效果图:
请勿发布不友善或者负能量的内容。与人为善,比聪明更重要!
该博客于2020-12-7日,后端基于go语言的beego框架开发
前端页面使用Bootstrap可视化布局系统自动生成
是我仿的原来我的TP5框架写的博客,比较粗糙,底下是入口
侯体宗的博客
文章标签
友情链接