!!微信支付总结(原创)

简介: Q:微信支付成功之后如何跳转到指定页面A:以微信公众号支付举例,在前台H5页面中指定即可,注意在后台设定的notify_url不是这个指定页面,notify_url是用来微信支付完成后,微信调用咱们的应用服务器用的,是一个回调接口可以用来记录日志,或者更新订单状态 参考文档:微信...

 

Q:

微信支付成功之后如何跳转到指定页面

A:

以微信公众号支付举例,在前台H5页面中指定即可,注意在后台设定的notify_url不是这个指定页面,notify_url是用来微信支付完成后,微信调用咱们的应用服务器用的,是一个回调接口

可以用来记录日志,或者更新订单状态

 

参考文档:

微信支付问题,支付成功后跳转到指定页面

微信支付分为四步:
1、获取code
2、获取opendi
3、获取相应数据得到商品订单数组
4、支付返回(js 判断)
PHP语言
include("includes/modules/payment/WxPayPubHelper.php");
   //使用jsapi接口
   $jsApi = new JsApi_pub();
   //=========步骤1:网页授权获取用户openid============
   //通过code获得openid
   if (!isset($_GET['code']))
   {
       //触发微信返回code码
       $url = $jsApi->createOauthUrlForCode(WxPayConf_pub::JS_API_CALL_URL);
       ecs_header("Location: $url");
   }else
   {
       //获取code码,以获取openid 
       $code = $_GET['code'];
       $jsApi->setCode($code);
       $openid = $jsApi->getOpenId();
       if(!empty($openid)){
           include_once('includes/lib_clips.php');
           include_once('includes/lib_payment.php');
          获取订单信息
  }
         $unifiedOrder = new UnifiedOrder_pub();
       
       //设置统一支付接口参数
       //设置必填参数
       //appid已填,商户无需重复填写
       //mch_id已填,商户无需重复填写
       //noncestr已填,商户无需重复填写
       //spbill_create_ip已填,商户无需重复填写
       //sign已填,商户无需重复填写
       $unifiedOrder->setParameter("openid","$openid");//商品描述
       $out_trade_no = $order['order_sn'];
       $unifiedOrder->setParameter("body","$goods_name");//商品描述
       //自定义订单号,此处仅作举例
       //$timeStamp = time();
       //$out_trade_no = WxPayConf_pub::APPID."$timeStamp";
       $total_fee    =    $total['amount']*100;
       $unifiedOrder->setParameter("out_trade_no","$out_trade_no");//商户订单号
       $unifiedOrder->setParameter("total_fee","$total_fee");//总金额
       $unifiedOrder->setParameter("notify_url",WxPayConf_pub::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();
       //=========步骤3:使用jsapi调起支付============
       $jsApi->setPrepayId($prepay_id);

       $jsApiParameters = $jsApi->getParameters();
       //$jsApiParameters = json_encode($jsApiParameters);
       $smarty->assign('pay_online', $jsApiParameters);




JavaScript语言
<</span>script type="text/javascript">

       //调用微信JS api 支付
       function jsApiCall()
       {
           WeixinJSBridge.invoke(
               'getBrandWCPayRequest',
               {$pay_online},
               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);
                       window.location.href="http://blog.sina.com.cn/u/XXXX";
                   }else{
                       //返回跳转到订单详情页面
                       alert("支付失败");
                       window.location.href="http://blog.sina.com.cn/u/XX";
                         
                   }
               }
           );
       }

       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();
           }
       }

   <</span>/script>

 

如何联系我:【万里虎】www.bravetiger.cn 【QQ】3396726884 (咨询问题100元起,帮助解决问题500元起) 【博客】http://www.cnblogs.com/kenshinobiy/
目录
相关文章
|
7月前
|
Android开发
一些微博问题的解决(原创)
一些微博问题的解决(原创)
34 1
|
开发者
01 公众号与公众平台
01 公众号与公众平台
231 0
01 公众号与公众平台
|
小程序 安全 前端开发
从零玩转系列之微信支付开篇
从零玩转系列之微信支付开篇
108 0
从零玩转系列之微信支付开篇
|
XML JSON JavaScript
【微信支付】精选干货带你使用微信公众号调起微信支付
最近搞了个微信公众号拉起微信支付的功能项目,看了微信官方文档之后,我从不懂变成了迷糊,又看了几遍之后,发现我从迷糊变成了懵逼状态。
564 0
【微信支付】精选干货带你使用微信公众号调起微信支付
|
移动开发 小程序 Java
【微信公众号】微信 jsapi 支付大概流程
jsapi 支付可运用于微信小程序和 h5 jsapi 支付不会弹出二维码(这点与 native 支付不同) jsapi 支付运用于移动端 native 支付运用于 PC 端
747 0
【微信公众号】微信 jsapi 支付大概流程
|
JavaScript 算法 NoSQL
微信公众平台开发(四)——微信支付
公众号中的微信支付需要通过JS来实现。微信JS-SDK是微信公众平台面向网页开发者提供的基于微信内的网页开发工具包。
|
JSON 前端开发 JavaScript
微信支付教程系列之公众号支付
目录 (一)微信公众号开发之VS远程调试 (二)微信公众号开发之基础梳理 (三)微信公众号开发之自动消息回复和自定义菜单 (四)微信公众号开发之网页授权获取用户基本信息 (五)微信公众号开发之网页中及时获取当前用户Openid及注意事项 (六)微信公众号开发之扫码支付 (七)微信公众号开发之公众号支付 (八)微信公众号开发之现金红包           今天,我们接着讲微信支付的系列教程,前面,我们讲了这个微信红包和扫码支付。
1713 0
博客入驻
我的博客即将入驻“云栖社区”,诚邀技术同仁一同入驻。 $(function () { $('pre.prettyprint code').
1007 0
微信公众平台原创声明和留言功能面向微信认证帐号公测
  昨天夜间微信公众平台原创声明和留言功能正式面向微信认证帐号公测了,网友直呼“那我有继续写的动力了,我要继续曾经中断的码字工作了”“支持原创,为自己代言”“知识产权越来越被重视,给666个赞”“作为一个个人公众号,意外获得原创功能,真的很暖心了。
1584 0