微信公众号JSAPI支付

微信公众号JSAPI支付
   一:配置参数
    申请成功后,获取接口文件, 将所有文件放入项目根目录weixin下,在WxPay.ub.config.php中填入配置账户信息;
 
  二:设置授权
       开发者中心->网页服务->网页授权获取用户基本信息->修改;  
    “授权回调页面域名修改成你的域名地址即可,须保证网页授权已获得,不然会报redirect_uri 参数错误;
 
 三:网页授权获取用户openid
          js_api_call.php 请求文件中改动(所有传给微信的参数都在入口文件中接收)
      $out_trade_no = $_GET['out_trade_no']; //商户系统内部订单号  32个字符内
      $total_fee = $_GET['total_fee']*100; //订单总金额  单位为分,不能带小数点,所以须把价格乘以100,
        不然获取prepay_id时会报错误(设置金额字段时最好设为小数点后2位)
    $pay_status =  get_pay_status($out_trade_no);//查看订单支付状态
    $return_url = get_return_url($out_trade_no); //设置支付成功后跳转页面
       //使用jsapi接口
      $jsApi = new JsApi_pub();
        //通过code获得openid
    if (!isset($_GET['code'])) {     //触发微信返回code码
        //设置redirect_uri参数,返回code码地址,其实就是重定向到当前页面,获取用户code码参数
        $url = WxPayConf_pub::JS_API_CALL_URL."?showwxpaytitle=1&out_trade_no=$out_trade_no&total_fee=$total_fee";
        $url = $jsApi->createOauthUrlForCode($url);
        Header("Location: $url");
    }else{          //获取code码,以获取openid
        $code = $_GET['code'];
        $jsApi->setCode($code);
        $openid = $jsApi->getOpenId(); //用户标识
    }
        再就是WxPayHubHelper.php文件 JsApi_pub()类下createOauthUrlForCode($redirectUrl)方法, 第二个参数
 改为 $urlObj["redirect_uri"] = urlencode($redirectUrl); //对$url变量进行url编码 不然header重定向时无法获取订单号和金额
     
四:设置统一支付接口参数,获取prepay_id  (预支付ID 微信生成的预支付 ID,用于后续接口调用中使用)
                 微信支付->开发配置->支付测试->测试授权目录和测试白名单添加  
(支付授权目录需要精确到最细一级的目录,且在使用时,目录名称后直接加文件名,如ccc.com/weixin/)
      确保你 WxPayPubHelper.php文件里 UnifiedOrder_pub 这个类的getPrepayId这个方法能正常使用
    这一步的调试在 getPrepayId()内 var_dump($this->result); 就能看到错误代码;
      posXml这个方法后调用了createXml这个方法
    function postXml() {
        $xml = $this->createXml();
        //**在此处查看xml文件是否正常生成
        include_once("log_.php");
            $log = new Log_();
            $log->log_result("log.txt",$xml);
        //** 由于打印一些xml格式的文件只显示字符长度,不显示内容。于是用log的形式写在服务器上调试
        $this->response = $this->postXmlCurl($xml,$this->url,$this->curl_timeout);
        return $this->response;
    }
  保证xml这个变量格式如下;
        <xml><openid><![CDATA[UKqsyD_711nkk2c]]></openid>
        <body><![CDATA[pay]]</body>
        <out_trade_no>201504101658571802></out_trade_no>
        <total_fee>120</total_fee>
        <notify_url><![CDATA[http://www.hao123.com/weixin/notify_url.php]]></notify_url>
        <trade_type><![CDATA[JSAPI]]></trade_type>
        <appid><![CDATA[wxfd3c4asdf]]></appid>
        <mch_id>123334333102</mch_id>
        <spbill_create_ip><![CDATA[192.168.0.1]]></spbill_create_ip>
        <nonce_str><![CDATA[imsdasdcmlkhfa]]></nonce_str>
        <sign><![CDATA[CBE62F36806A3E1]]></sign></xml>
参数正确,postXmlCurl才能正确提交,提交后就能得到正确的prepay_id,就能弹出支付框了

五:使用jsapi调起支付
      根据prepay_id生成jsapi支付参数
      $jsApi->setPrepayId($prepay_id);
     $jsApiParameters = $jsApi->getParameters();
      //调用微信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") { //支付成功后
                            window.location.href="<?php echo $return_url;?>"  //跳转地址及订单操作,在异步页面也须处理订单,防止同步时失败      
                    }else{
                        alert("支付失败"+res.err_code+res.err_desc+res.err_msg);
                    }
                }
            );
        }(每次请求callpay方法时须判断订单状态,防止重复提交)
 
六:通用通知接口 异步处理微信返回结果
         支付完成后,notify.php中获取微信的回调
        $xml = $GLOBALS['HTTP_RAW_POST_DATA'];
    //须验证签名,并回应微信。
   if($notify->checkSign() == TRUE)     //签名验证通过并更新订单状态后
    $notify->setReturnParameter("return_code","SUCCESS"); //设置返回码,保证支付状态改变后才返回成功
         //对后台通知交互时,如果微信收到商户的应答不是成功或超时,微信认为通知失败,
         //微信会通过一定的策略(如30分钟共8次)定期重新发起通知,
     $returnXml = $notify->returnXml();
      echo $returnXml;(将xml数据返回微信     当return_code为SUCCESS时,不会再通知)
   //当收到通知进行处理时,首先检查对应业务数据的状态,判断该通知是否已经处理过,如果没有处理过再进行处理,
    如果处理过直接返回结果成功。在对业务数据进行状态检查和处理之前,要采用数据锁进行并发控制,
    以避免函数重入造成的数据混乱.
          //判断是否在微信浏览器打开
          function isWeiXin(){
            var ua = window.navigator.userAgent.toLowerCase();
            if(ua.match(/MicroMessenger/i) == 'micromessenger'){
              return true;
             }else{
             return false;
          }
      }

    步骤够详细了吧,我自己实现过,所以写了日志,结合php版本的demo 大致弄得出来了,如果对整个流程不太清楚,仔细的看完微信公众号支付接口文档,你申请微信公众号支付成功了就会有的
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1、WeixinApi为何诞生 以前顺便玩儿了下微信公众账号,做Web前端开发的,都对页面脚本充满好奇,所以研究了下,放到Blog上, 也正因为微信官方一直没有放出正式的Api提供给用户来用,所以大量的用户到我blog上去询问WeixinJSBridge相关的技术点,索性我就整理了一下, 起个名字叫WeixinApi开源到github来,提供给大家使用! 2、免责声明 此Api为非官方版,由于官方的限制,继续使用此Api还有可能会出现一些意向不到的问题,一切后果请自行承担! 3、WeixinApi可能停止更新 目前官方已经出了正式版本的SDK,详情可见微信JS-SDK说明文档, 所以大家还是尽早迁移到官方版本吧,这对大家来说是好事,以后出什么问题,官方渠道应该都会第一时间给出解决方案,稳定很多,也不至于经常被黑! 本API可能以后就不会频繁更新了,各位知晓! 快速使用方法: // 定义微信分享的数据 var wxData = {     "appId": "", // 服务号可以填写appId     "imgUrl" : 'http://photocdn.sohu.com/20130122/Img364302298.jpg',     "link" : 'http://www.baidufe.com',     "desc" : '使用警告:此Api非官方版本,请各位尽量将分享功能迁移至腾讯官方版,会更稳定些!',     "title" : "欢迎使用WeixinApi" }; // 分享的回调 var wxCallbacks = {     // 收藏操作是否触发回调,默认是开启的     favorite : false,     // 分享操作开始之前     ready : function() {         // 你可以在这里对分享的数据进行重组         alert("准备分享");     },     // 分享被用户自动取消     cancel : function(resp) {         // 你可以在你的页面上给用户一个小Tip,为什么要取消呢?         alert("分享被取消,msg="   resp.err_msg);     },     // 分享失败了     fail : function(resp) {         // 分享失败了,是不是可以告诉用户:不要紧,可能是网络问题,一会儿再试试?         alert("分享失败,msg="   resp.err_msg);     },     // 分享成功     confirm : function(resp) {         // 分享成功了,我们是不是可以做一些分享统计呢?         alert("分享成功,msg="   resp.err_msg);     },     // 整个分享过程结束     all : function(resp,shareTo) {         // 如果你做的是一个鼓励用户进行分享的产品,在这里是不是可以给用户一些反馈了?         alert("分享"   (shareTo ? "到"   shareTo : "")   "结束,msg="   resp.err_msg);     } }; // 自定义分享到:微信好友、朋友圈、腾讯微博、QQ好友 WeixinApi.share(wxData,wxCallbacks); 标签:WeixinApi

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值