微信--订单处理页:

<?php
    include("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))
        {
            goto获取到相应的订单参数
        }
    
        //=========步骤2:使用统一支付接口,获取prepay_id============
        //使用统一支付接口
        $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);
        $smarty->assign('openid',$openid);
        $smarty->assign('order_id',$order_id);//订单id用于支付成功跳转订单页
        $smarty->display('order_done.dwt');
        //echo $jsApiParameters;

}

?>

微信支付页:请注意标红处。此处为支付成功后跳转

<html>
<head>
    <meta http-equiv="content-type" content="text/html;charset=utf-8"/>
    <title>微信安全支付</title>

<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://xxxxxx";
                    }else{
                        //返回跳转到订单详情页面
                        alert(支付失败);
                        window.location.href="http://xxxxx/index.php?wxid={$openid}";
                           
                    }
                }
            );
        }

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>
    </br></br></br></br>
    <div align="center">
        <button style="width:610px; height:160px; border:0px #FE6714 solid; cursor: pointer;  color:white;  font-size:64px;" type="button" οnclick="callpay()" >给我一分钱</button>
    </div>
</body>
</html>

异步处理页:必须echo success

<?php
//使用log文件形式记录回调信息。

include("log_.php");
    include("WxPayPubHelper.php");

//使用通用通知接口
    $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="./notify_url.log";//log文件路径
    $log_->log_result($log_name,"【接收到的notify通知】:\n".$xml."\n");

if($notify->checkSign() == TRUE)
    {
        //进行订单处理:
        //商户自行增加处理流程,
        //例如:更新订单状态
        //例如:数据库操作
        //例如:推送支付完成信息
    }

$fp = fopen('./a.txt', 'a+b');
    fwrite($fp, var_export($xml, true));
    fclose($fp);

?>

转载于:https://www.cnblogs.com/langxi/p/4387476.html

微信支付 支付成功后不跳转 ecshop微信支付 如下操作即可相关推荐

  1. 微信注册验证成功之后不跳转_微信为什么会被限制登录?被限制后我们该怎么办?...

    有许多朋友问过我这样的问题,那就是自己的微信被"限制登入"了,这是什么原因?又要如何处理?其实这个问题我很早之间也为大家分享过,首先我们来看下你的微信为什么会被限制登入. 其实微信 ...

  2. 支付宝支付 第十一集:支付回调成功后的监听

    支付宝支付 第十一集:支付回调成功后的监听 一.代码 目录结构 更新OrderDetailController.java package com.dzy.alipay.web.order; impor ...

  3. cas后端返回html直接跳转,CAS验证成功后不能跳转到登陆成功的主页面解决办法...

    CAS验证成功后不能跳转到登陆成功的主页面 现在部署了CAS,有一个应用,下载输入应用的URL可以正确跳转到CAS服务的登陆界面,登陆验证通过后页面却跳转到了应用的登陆界面,不能直接进入登陆成功的主页 ...

  4. Ajax请求成功后页面跳转

    文章目录 Ajax实现页面局部刷新 Ajax请求成功后页面跳转 Ajax实现页面局部刷新 这里通过点击一个按钮,然后下面产生一段文字,而整个页面不用刷新 <!DOCTYPE html> & ...

  5. 织梦ajax登录界面,dede织梦后台登陆成功后又跳转到登陆页面

    dede织梦后台登陆成功后又跳转到登陆页面怎么办?相信在很多个人站长朋友们在dede建站运营中都有遇到过类似的问题,在登陆界面输入账号密码后会有3-5秒的卡顿才会进入下面的页面,然后再卡顿3-5秒就跳 ...

  6. SpringBoot不使用Thymeleaf的ajax成功后html跳转

    一.SpringBoot不使用Thymeleaf的ajax成功后html跳转 如图所示,ajax请求成功之后,这样子跳转页面是失败的 二.解决办法 在该目录下新建static文件夹,把html放在这里

  7. BUG集合-微信分享点击之后无法跳转到微信app应用进行分享

    微信分享点击之后无法跳转到微信app应用进行分享 微信分享点击之后无法跳转到微信app应用进行分享的错误原因:提供的缩略图过大,所以无法跳转, 这个参数需要的图片不能过大 解决方案:1.换一张小的图片 ...

  8. 库存出现负数 mysql_前台支付商品成功后,sku表库存,购买数量会重复执行减操作好几次了,导致库存为负数...

    ** _### 测试下来问题出现在,支付成功后这个节点,反复执行了好几次了product_sku 字段的更新. **_ [ 2020-01-08T16:51:06+08:00 ] 140.207.54 ...

  9. 登录成功后怎么跳转页面html,怎么设置登录成功后跳转到相应的页面

    想要用angularjs实现的功能是 一进入就是一个登录页面(login.html),如果没有账号密码就注册,登录成功后跳转到相应的页面(shopcart.html) 碰到的问题 1.一进入页面没有显 ...

最新文章

  1. 036_Unicode对照表二
  2. Spring Boot Actuator
  3. Ubuntu NFS服务器的配置
  4. ORACLE会话数、连接数配置
  5. “中国智造”为System x提供创新源动力
  6. Android 使用jarsigner给apk签名的方法详细介绍
  7. java 观察者模式_Java技术干货分享:深入理解观察者模式原理与技术
  8. Canny边缘检测算法原理及其VC实现详解(一)
  9. Android零基础入门第21节:ToggleButton和Switch使用大全
  10. LeetCode 5376. 非递增顺序的最小子序列
  11. POJ 2411.Mondriaan's Dream 解题报告
  12. c#生成静态库_在 Blazor WebAssembly 静态网站中部署ML.NET机器学习模型
  13. java 信号处理模块_GitHub - Astoros-Fung/JavaDsp: 数字信号处理(DSP)方面的Java封装,包含常用的一些处理方法,如滤波、信号变换等等。...
  14. nginx配置CSP策略和Nonce随机数方案
  15. 英国高中A-Level和IB课程介绍
  16. 数值计算和SVM讲解(下)
  17. 免费思维导图软件,收藏
  18. WAF应用防火墙的功能
  19. 一个汉字笔画库 hanzi-writer 的小应用
  20. 如何高效的配置Nginx

热门文章

  1. 英国莽汉司机认罪:放任特斯拉自动驾驶,自己躺在副驾悠哉悠哉
  2. 扎克伯格5小时听证鏖战:五大焦点,四处尴尬,一次耿直CEO笑翻全场
  3. 面对数据缺失,如何选择合适的机器学习模型?
  4. 感知机PLA算法实现[转载]
  5. 这不是我想要的Serverless
  6. 十一项全球最具权威的大数据资质认证
  7. OOAD理论知识小结
  8. VBS去除字符串的重复项并统计重复字符出现的次数
  9. MongoDB Hot Backup 测试及痛点
  10. Cookie 和 Session机制具体解释