Thinkphp微信公众号支付接口_php技巧

本文实例为大家分享了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.jb51.net/201608/yuanma/Thinkphpwenxinport(jb51.net).rar

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

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索thinkphp支付接口
thinkphp公众号支付
thinkphp 支付宝接口、thinkphp银联支付接口、thinkphp 支付接口、thinkphp微信支付接口、thinkphp 公众号支付,以便于您获取更多的相关知识。

时间: 2024-11-03 06:37:41

Thinkphp微信公众号支付接口_php技巧的相关文章

Java微信开发之公众号支付接口

1.设置支付路径 使用微信公众号支付接口,必须在微信公众号管理后台中设置支付路径.这个微信接口文档说得很清楚,请参考:https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=7_3 2.公众号支付业务流程 简单的描述就是: 首先需要根据我们自己的订单(4),也就是需要支付的明细,然后使用统一下单API向微信请求生成微信看得懂的订单(5),然后生成支付参数及签名(6),在支付页面根据支付配置及微信统一订单的prepay_id,发起微信支付(

微信支付PHP SDK之微信公众号支付代码详解_php实例

这里假设你已经申请完微信支付 1. 微信后台配置  如图 我们先进行测试,所以先把测试授权目录和 测试白名单添加上.测试授权目录是你要发起微信请求的哪个文件所在的目录. 例如jsapi 发起请求一般是jsapi.php所在目录 为测试目录,测试白名单即开发人员的微信号. 正式的支付授权目录不能和测试的一样否则会报错.不填写或者填错授权目录以及测试白名单都会报错. 报错样例: NaNsystem:access_denied 不在测试白名单 2. 配置 lib/WxPay.Config.php文件

微信公众号支付之坑:调用支付jsapi缺少参数 timeStamp等错误解决方法_php实例

这段时间一直比较忙,一忙起来真感觉自己就只是一台挣钱的机器了(说的好像能挣到多少钱似的,呵呵):这会儿难得有点儿空闲时间,想把前段时间开发微信公众号支付遇到问题及解决方法跟大家分享下,这些"暗坑"能不掉就不掉吧,要不然关键时刻出问题,真是让人急的焦头烂额.  双12客户的商城活动正在蓄势进行中,却有用户频频反馈说:支付不了,有问题,并截图如下:   当时问题感觉很奇怪,自己测试多次都ok啊,问题来了都赶紧解决吧,最终找到解决办法: 原因是程序中一个字符串变量被错误的设置为数字类型,解决

nodejs微信公众号支付开发_node.js

odeJs 微信公众号功能开发,移动端 H5页面调用微信的支付功能.这几天根据公司的需要使用 node 和 h5页面调用微信的支付功能完成支付需求.现在把开发过程重新捋一遍,以帮助更多的开发者顺利的完成微信支付功能的开发.(微信暂时还没有提供 node 的支付功能) 一.请求CODE 请求 code 的目的就是获取用户的 openid(用户相对于当前公众号的唯一标识) 和access_token,请求的API:https://open.weixin.qq.com/connect/oauth2/a

代码-微信公众号支付获取不到notify_url通知

问题描述 微信公众号支付获取不到notify_url通知 2015-07-23 10:06:07,848 INFO -SaleAction.wechat_paymentResult 微信支付后台通知结果:{} 2015-07-23 10:06:07,848 INFO -微信支付后台通知结果: 微信支付后台通知结果:{} 2015-07-23 10:06:07,849 INFO -微信支付后台通知结果: 微信支付后台通知结果:{} 2015-07-23 10:06:07,849 INFO -微信支

微信公众号支付测试功能策略调整 加快商户申请速度

小马哥昨在世界互联网大会上发表"腾讯将专注于做互联网的连接器"的演讲,其中谈到了腾讯开放的原则.这不微信团队就立马响应了号召,宣布微信公众号支付测试功能策略调整,精简申请环节,加快商户申请速度.公告如下 微信公众号支付测试功能策略调整 为进一步加快商户申请速度,精简申请环节,微信公众号支付测试功能在原有基础上做出如下优化调整: 1.取消测试状态 微信公众号支付申请流程取消测试状态,商户提交资料通过审核后,可直接进入全网状态,允许所有的微信号发起支付.策略调整后测试功能(测试目录和白名单

关于微信公众号支付的问题

问题描述 关于微信公众号支付的问题 现在微信公众号支付功能已经实现,但是现在有一个问题,在调起预支付订单时,我在后台订单表中生成一条订单记录且订单记录状态为未支付状态,现在我在使用微信支付的中途停止了支付,支付中断,这样在数据库里面会有一条尚未支付的订单记录,用户在'我的订单'中也可以看到未支付的订单,我提供一个按钮让用户继续支付.然而,这里的代码,实现的思路是什么?求救了 解决方案 微信公众号支付微信支付之公众号支付

微信公众号支付(一)如何获取用户openId_java

一.获取apikey,appsecret与商户号 注册公众号.商户号 二.获取用户的OpenId 1.设置[授权回调页面域名] 官方解释:用户在网页授权页同意授权给公众号后,微信会将授权数据传给一个回调页面,回调页面需在此域名下,以确保安全可靠.回调页面域名不支持IP地址. 2.用户同意授权 我是把这个url写在微信菜单下的,当进入这个页面的时候就让用户同意.注意:好像是静默授权的,用户不知道 1.url:https://open.weixin.qq.com/connect/oauth/auth

使用开源库MAGICODES.WECHAT.SDK进行微信公众号支付开发

    概要 博客使用Word发博,发布后,排版会出现很多问题,敬请谅解.可加群获取原始文档. 本篇主要讲解微信支付的开发流程,相关业务基于MAGICODES.WECHAT.SDK实现.通过本篇教程,您可以很方便的快速完成微信公众号支付的开发. 关于Magicodes.WeChat.SDK MAGICODES.WECHAT.SDK为心莱团队封装的轻量级微信SDK,现已全部开源,开源库地址为:https://github.com/xin-lai/Magicodes.WeChat.SDK 更多介绍,