温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Thinkphp微信公众号JSAPI支付,微信支付简易实例

发布时间:2020-07-21 01:08:42 来源:网络 阅读:1852 作者:取什么昵称 栏目:web开发
  1. 官方微信支付文档 https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=7_1
  2. 下载php版本demo
    Thinkphp微信公众号JSAPI支付,微信支付简易实例
    3.后端具体调用代码如下:

    
    <?php
    namespace app\common\library;
    class Pay
    {
    
    public function wxpay($openId,$goods,$order_sn,$total_fee,$attach='')
    {
        require_once APP_PATH."/common/library/php_sdk/lib/WxPay.Api.php";
        require_once APP_PATH."/common/library/php_sdk/lib/WxPay.JsApiPay.php";
        require_once APP_PATH."/common/library/php_sdk/example/log.php";
        // $logHandler= new CLogFileHandler(APP_ROOT."/Api/wxpay/logs/".date('Y-m-d').'.log');
        // $log = Log::Init($logHandler, 15);
    
        $tools = new \JsApiPay();
        if(empty($openId)) $openId = $tools->GetOpenid();
        $config = new \WxPayConfig();
        $input = new \WxPayUnifiedOrder();
        $input->SetBody($goods);     //商品名称
        $input->SetAttach($attach);     //附加参数,可填可不填,填写的话,里边字符串不能出现空格
        $input->SetOut_trade_no($order_sn);   //订单号
        $input->SetTotal_fee($total_fee * 100);   //支付金额,单位:分
        $input->SetTime_start(date("YmdHis"));  //支付发起时间
        $input->SetTime_expire(date("YmdHis", time() + 600));//支付超时
        $input->SetGoods_tag("test3");
        //$input->SetNotify_url("http://".$_SERVER['HTTP_HOST']."/payment.php"); //支付回调验证地址
        $input->SetNotify_url("http://".$_SERVER['HTTP_HOST']."/web/payment/notify/WeixinPay/notify");
        $input->SetTrade_type("JSAPI");    //支付类型
        $input->SetOpenid($openId);     //用户openID
        $order = \WxPayApi::unifiedOrder($config,$input); //统一下单
        // dump($order);exit;
        $jsApiParameters = $tools->GetJsApiParameters($order);
        return $jsApiParameters;
    }

}

    $pay = new \app\common\library\Pay();
    $res = $pay->wxpay($this->openid,'开通会员',$order['order_no'],$order['money']);

4.前端js核心代码如下:
    function jsApiCall(data,id)
    {
        data = JSON.parse(data);
        WeixinJSBridge.invoke(
        'getBrandWCPayRequest', data,
            function(res){
                WeixinJSBridge.log(res.err_msg);
                if(res.err_msg == "get_brand_wcpay_request:ok"){
                    layer.msg('支付成功', {time: 2500}, function () {
                        location.href = "{:url('xxx/xxx')}";
                    });
                }else if(res.err_msg == "get_brand_wcpay_request:cancel"){
                    layer.msg("支付取消!", {time: 1800});
                }else{
                    layer.msg("支付失败!", {time: 1800});
                }
            }
        );
    }
    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();
        }
    }
    $('.see_price').click(function() {
        index = layer.load(1, {shade: [0.1,'#fff'] });
        var $id = $(this).attr('name');
        $.ajax({
                type: 'post', //可选get
                url: '{:url("xxx/xxx")}', //这里是接收数据的PHP程序
                data: 'id='+$id, //传给PHP的数据,多个参数用&连接
                dataType: 'Json', //服务器返回的数据类型 可选XML ,Json jsonp script html text等
                success: function(msg) {
                    if (msg.code == '200') {
                        layer.close(index);
                        jsApiCall(msg.info);
                    } else {
                        layer.close(index);
                        layer.msg(msg.message, {time: 1800});
                    }
                },
                error: function() {
                    layer.close(index);
                    layer.msg("提交失败!", {time: 1800});
                }
            });
    });
向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI