• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >微信小程序 > Tp框架实现微信支付接口

Tp框架实现微信支付接口

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-11-30

匿名通过本文主要向大家介绍了thinkphp微信支付接口,微信公众号支付接口,thinkphp支付接口,thinkphp公众号支付等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com
这篇文章主要为大家详细介绍了Thinkphp微信公众号支付接口,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了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>

  </p>
 </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



 
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • Tp框架实现微信支付接口
  • 用tp框架实现微信支付的代码实例

相关文章

  • 2018-11-30微信小程序表单验证功能完整实例
  • 2017-06-20微信小程序跟读 demo代码
  • 2018-11-30微信小程序之开发环境的搭建 (图文)
  • 2018-11-30怎么开发微信小程序的获取用户手机号功能
  • 2018-08-20微信小程序媒体组件 audio
  • 2018-11-30怎样使用React虚拟DOM
  • 2018-11-30小程序开发教程文档
  • 2018-08-20微信小程序可滚动视图区域 scroll-view
  • 2018-11-30PPI如何使用?总结PPI实例用法
  • 2018-11-30教你做一个开源的小程序计算器

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • 微信小程序 实战小程序实例
    • 大数据还可以这么用,你知道吗?
    • 在不同的移动设备上小程序应该如何设置rpx单位?
    • 微信小程序-小商城前台
    • 微信小程序(应用号)开发新闻客户端实例
    • 微信小程序表单组件picker-view(嵌入页面的滚动选择器)
    • 实例详解微信小程序wx.request 的封装
    • 微信小程序中如何改变button按钮的样式
    • 微信小程序组件化开发框架Labrador的特性安装步骤
    • 微信小程序 教程之事件

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有