Thinkphp微信公众号支付接口


Posted in PHP onAugust 04, 2016

本文实例为大家分享了Thinkphp微信公众号支付接口,供大家参考,具体内容如下

第一步  先把文件夹的那两个图片 配置成一样的路径 除了域名要改 其他保持一致。

第二步  把 Weixinpay 这个文件夹放在 \ThinkPHP\Library\Vendor  将Weixinpay文件夹放置到这个Vendor文件夹中

第三步  把  WxJsAPIController.class.php 这个php文件  \Home\Controller  这里面

第四步  把 WxJsAPI这个文件夹  放置在 \Home\View  这个里面

第五步 成功调用微信公众号支付功能

jsApiCall.html

<!DOCTYPE html>
 <html>
 <head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta name='viewport' content='width=device-width, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0'/>
  <title>微信安全支付</title>



  <script type="text/javascript">
    //调用微信JS api 支付
    function jsApiCall()
    {
      WeixinJSBridge.invoke(
        'getBrandWCPayRequest',
        <?php echo $jsApiParameters; ?>,
        function(res){
          WeixinJSBridge.log(res.err_msg);
          if(res.err_msg == "get_brand_wcpay_request:ok"){
          //alert(res.err_code+res.err_desc+res.err_msg);
            /*这里写如果支付成功的话执行什么操作*/
          }else{
            //返回跳转到订单详情页面
            alert(支付失败);
              
          }
        }
      );
    }
    function callpay()
    {
      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();
      }
  
  
    }
 



 
  </script>
 </head>
 <body>
 <button style="width:210px; height:30px; background-color:#FE6714; border:0px #FE6714 solid; cursor: pointer; color:white; font-size:16px;" type="button" onclick="jsApiCall()" id="asd" >购买</button>

  </div>
 </body>
 </html>

WxJsAPIController.class.php

<?php

namespace Home\Controller;
use Think\Controller;

class WxJsAPIController extends Controller{
  public function _initialize()
  {
    //引入WxPayPubHelper
    vendor('Weixinpay.WxPayPubHelper');
  }  

  public function jsApiCall()
  {  

    //使用jsapi接口
    $jsApi = new \JsApi_pub();
    
    //=========步骤1:网页授权获取用户openid============
    //通过code获得openid
    //
    //

    if (!isset($_GET['code']))
    {
      //触发微信返回code码
      $rUrl=urlencode(C('WxConfig.JS_API_CALL_URL').'/id/'.$_GET[id]);  
      /*注意一下这个 id 是为了可以成功的传个 id值才这样写 如果你不需要的话也可以直接写成
  $rUrl=urlencode(C('WxConfig.JS_API_CALL_URL'));

      $this->redirect('WxJsAPI/jsApiCall',array('id' =>55),0, '页面跳转中...');
      我是这样穿这个id过来的值得你们也可以自己改成其他的来传这个id 或是删除他不要
      */
       

      $url = $jsApi->createOauthUrlForCode($rUrl);
      // echo $url;exit();
      Header("Location: $url");
    }else
    {

      //获取code码,以获取openid
      $code = $_GET['code'];
      $jsApi->setCode($code);
      $openid = $jsApi->getOpenId();//openid 这里是为了获取用户当前的openid 如果你有做微信登陆的话就可以无视他。
    }



    //=========步骤2:使用统一支付接口,获取prepay_id============
    //使用统一支付接口
    $unifiedOrder = new \UnifiedOrder_pub();

      /*此处做数据库的查询 这里操作数据库把产品信息显示出来*/

      /*此处做数据库的查询 这里操作数据库把产品信息显示出来*/


    //设置统一支付接口参数
    //设置必填参数
    //appid已填,商户无需重复填写
    //mch_id已填,商户无需重复填写
    //noncestr已填,商户无需重复填写
    //spbill_create_ip已填,商户无需重复填写
    //sign已填,商户无需重复填写
    //

    $NOTIFY_URL="你的域名/index.php/Home/WxJsAPI/notify";

    $unifiedOrder->setParameter("openid",$openid);//openid
    $unifiedOrder->setParameter("body",'商品的名字');//商品描述
    $unifiedOrder->setParameter("out_trade_no",'123456789');//商户订单号
    $unifiedOrder->setParameter("total_fee",1*100);//总金额 微信的钱1*100等于1
    $unifiedOrder->setParameter("notify_url",$NOTIFY_URL);//通知地址
  

    $unifiedOrder->setParameter("trade_type","JSAPI");//交易类型
    //非必填参数,商户可根据实际情况选填
    //$unifiedOrder->setParameter("sub_mch_id","XXXX");//子商户号
    //$unifiedOrder->setParameter("device_info","XXXX");//设备号
    //$unifiedOrder->setParameter("attach","XXXX");//附加数据
    //$unifiedOrder->setParameter("time_start","XXXX");//交易起始时间
    //$unifiedOrder->setParameter("time_expire","XXXX");//交易结束时间
    //$unifiedOrder->setParameter("goods_tag","XXXX");//商品标记
    //$unifiedOrder->setParameter("openid","XXXX");//用户标识
    //$unifiedOrder->setParameter("product_id","XXXX");//商品ID
  

    $prepay_id = $unifiedOrder->getPrepayId();

    // echo $prepay_id;exit();
    //=========步骤3:使用jsapi调起支付============
    $jsApi->setPrepayId($prepay_id);
    
    $jsApiParameters = $jsApi->getParameters();

    $WEB_HOST='你的域名';//填写的话 如 http://nicaicai.imwork.net 最后面不用加 /
    $this->assign('HOSTS',$WEB_HOST);
    $this->assign('jsApiParameters',$jsApiParameters);
    $this->display();
    //echo $jsApiParameters;

  }


  public function notify()
  {
    //使用通用通知接口
    $notify = new \Notify_pub();

    //存储微信的回调
    $xml = $GLOBALS['HTTP_RAW_POST_DATA'];   

    $notify->saveData($xml);
    

    //验证签名,并回应微信。
    //对后台通知交互时,如果微信收到商户的应答不是成功或超时,微信认为通知失败,
    //微信会通过一定的策略(如30分钟共8次)定期重新发起通知,
    //尽可能提高通知的成功率,但微信不保证通知最终能成功。
    if($notify->checkSign() == FALSE){

      $notify->setReturnParameter("return_code","FAIL");//返回状态码
      $notify->setReturnParameter("return_msg","签名失败了啊");//返回信息
    }else{
      $notify->setReturnParameter("return_code","SUCCESS");//设置返回码
    }
    $returnXml = $notify->returnXml();
    echo $returnXml;
    
    //==商户根据实际情况设置相应的处理流程,此处仅作举例=======
    
    //以log文件形式记录回调信息
     // $log_ = new Log_();
    $log_name= __ROOT__."/Public/notify_url.log";//log文件路径
    
    
    if($notify->checkSign() == TRUE)
    {
      if ($notify->data["return_code"] == "FAIL") {


        //此处应该更新一下订单状态,商户自行增删操作
        log_result($log_name,"【通信出错】:\n".$xml."\n");
      }
      elseif($notify->data["result_code"] == "FAIL"){
    

        //此处应该更新一下订单状态,商户自行增删操作
        log_result($log_name,"【业务出错】:\n".$xml."\n");
      }
      else{ 

  /*查看支付成功的返回值请去 https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=9_1 */

  $xmlss=$notify->data["out_trade_no"];//订单号
  $total_fee=$notify->data['total_fee'];//订单总金额,单位为分,详见支付金额
    

    /*更新订单状态这里写数据库的操作*/
   
  /*更新订单状态这里写数据库的操作*/


        //此处应该更新一下订单状态,商户自行增删操作
        log_result($log_name,"【支付成功】:\n".$xml."\n");
      }
    
      //商户自行增加处理流程,
      //例如:更新订单状态
      //例如:数据库操作
      //例如:推送支付完成信息
    }
  }

  // 打印log
  public function log_result($file,$word)
  {
    $fp = fopen($file,"a");
    flock($fp, LOCK_EX) ;
    fwrite($fp,"执行日期:".strftime("%Y-%m-%d-%H:%M:%S",time())."\n".$word."\n\n");
    flock($fp, LOCK_UN);
    fclose($fp);
  }

}


?>

源码下载:http://xiazai.3water.com/201608/yuanma/Thinkphpwenxinport(3water.com).rar

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
定制404错误页面,并发信给管理员的程序
Oct 09 PHP
php 模拟POST|GET操作实现代码
Jul 20 PHP
php 大数据量及海量数据处理算法总结
May 07 PHP
解析php中如何直接执行SHELL
Jun 28 PHP
解析curl提交GET,POST,Cookie的简单方法
Jun 29 PHP
ThinkPHP3.1新特性之多数据库操作更加完善
Jun 19 PHP
PHP字符串比较函数strcmp()和strcasecmp()使用总结
Nov 19 PHP
php隐藏IP地址后两位显示为星号的方法
Nov 21 PHP
Laravel实现构造函数自动依赖注入的方法
Mar 16 PHP
PHP查看SSL证书信息的方法
Sep 22 PHP
php设计模式之建造器模式分析【星际争霸游戏案例】
Jan 23 PHP
php实现商城购物车的思路和源码分析
Jul 23 PHP
浅析Laravel5中队列的配置及使用
Aug 04 #PHP
PHP中如何判断exec函数执行成功?
Aug 04 #PHP
详解Laravel视图间共享数据与视图Composer
Aug 04 #PHP
yii的入口文件index.php中为什么会有这两句
Aug 04 #PHP
Laravel最佳分割路由文件(routes.php)的方式
Aug 04 #PHP
基于Swoole实现PHP与websocket聊天室
Aug 03 #PHP
浅析php如何实现App常用的秒发功能
Aug 03 #PHP
You might like
php header示例代码(推荐)
2010/09/08 PHP
php ios推送(代码)
2013/07/01 PHP
CakePHP框架Model关联对象用法分析
2017/08/04 PHP
php生成条形码的图片的实例详解
2017/09/13 PHP
我也种棵OO树JXTree[js+css+xml]
2007/04/02 Javascript
js 替换
2008/02/19 Javascript
Javascript 继承实现例子
2009/08/12 Javascript
JQUERY获取form表单值的代码
2010/07/17 Javascript
使用jQuery.fn自定义jQuery翻页插件
2013/01/20 Javascript
JS小功能(操作Table--动态添加删除表格及数据)实现代码
2013/11/28 Javascript
JavaScript检测上传文件大小的方法
2015/07/22 Javascript
js密码强度校验
2015/11/10 Javascript
AngularJS 依赖注入详解及示例代码
2016/08/17 Javascript
原生JS实现图片左右轮播
2016/12/30 Javascript
微信小程序 弹框和模态框实现代码
2017/03/10 Javascript
解决JS内存泄露之js对象和dom对象互相引用问题
2017/06/25 Javascript
使用vue-cli编写vue插件的方法
2018/02/26 Javascript
对angularJs中自定义指令replace的属性详解
2018/10/09 Javascript
JavaScript或jQuery 获取option value值方法解析
2020/05/12 jQuery
[02:43]DOTA2英雄基础教程 圣堂刺客
2013/12/09 DOTA
解决安装python库时windows error5 报错的问题
2018/10/21 Python
Python高斯消除矩阵
2019/01/02 Python
python 解决cv2绘制中文乱码问题
2019/12/23 Python
PyTorch中Tensor的数据统计示例
2020/02/17 Python
Tensorflow中的图(tf.Graph)和会话(tf.Session)的实现
2020/04/22 Python
Python实现一个简单的递归下降分析器
2020/08/01 Python
python输入中文的实例方法
2020/09/14 Python
详解python的变量缓存机制
2021/01/24 Python
利用CSS3的特性改变文本选中时的颜色
2013/09/11 HTML / CSS
什么是CSS3 HSLA色彩模式?HSLA模拟渐变色条
2016/04/26 HTML / CSS
Roots加拿大官网:加拿大休闲服饰品牌
2016/10/24 全球购物
英国领先的鞋类零售商和顶级品牌的官方零售商:Wynsors
2020/02/17 全球购物
销售总经理岗位职责
2014/03/15 职场文书
2014年终工作总结范本
2014/12/15 职场文书
日本读研:怎样写好一篇日本研究计划书?
2019/07/15 职场文书
JS中一些高效的魔法运算符总结
2021/05/06 Javascript