微信JS支付代碼_前端調用微信支付接口

轉自:http://dditblog.com/itshare_553.htmlhtml

跟你們分享一段微信支付的js代碼片斷、V3版的微信支付沒有paySignKey參數、基本上是直接複製就能夠使用了、改一改本身的參數就行了、話很少說、直接上代碼ajax

 

支付按鈕的點擊事件正則表達式

$(´.Save_Patient_Msg´).click(function(){
    $(´.Save_Patient_Msg´).off(´click´);
    var hrdfId = getOrderId();
    var txnAmt = $(´.sum_pay.font-red´).html(); 
     
    var data = {orderId: hrdfId, txnAmt: "0.01", 
        prodDesc: "遠程診斷服務", callType: "JSAPI",
        access_token: getUrlParam("access_token")
    };

    $.ajax({
        type: ´POST´,
        url: ´/hims/api/commonPay/queryTransNo?access_token=´ getUrlParam(´access_token´),
        dataType:´json´,
        contentType:´application/json´,
        data: JSON.stringify(data),
        success: function(Wxres){
          if(!Wxres){
            $.alert(´服務器擁堵,請稍後訪問´)
          }else{
              console.log(Wxres);
              if(Wxres.data.respCode == ´fail´){
                $.alert(Wxres.data.respMsg);
              }else{
                 //10 微信支付接口
                    // 10.1 發起一個支付請求
                    // 注意:此 Demo 使用 2.7 版本支付接口實現,建議使用此接口時參考微信支付相關最新文檔。
                    var param = Wxres.data;
                    wx.config({
                        debug: false, // 開啓調試模式,調用的全部api的返回值會在客戶端alert出來,若要查看傳入的參數,能夠在pc端打開,參數信息會經過log打出,僅在pc端時纔會打印。
                        appId: ´wx403ead26691402fb´, // 必填,公衆號的惟一標識
                        timestamp: param.timestamp, // 必填,生成簽名的時間戳
                        nonceStr: param.noncestr, // 必填,生成簽名的隨機串
                        signature: param.signJs,// 必填,調用js簽名,
                        jsApiList: [´chooseWXPay´] // 必填,須要使用的JS接口列表,這裏只寫支付的
                    });
                    wx.chooseWXPay({
                        timestamp: param.timestamp, // 支付簽名時間戳,注意微信jssdk中的全部使用timestamp字段均爲小寫。但最新版的支付後臺生成簽名使用的timeStamp字段名需大寫其中的S字符
                        nonceStr: param.noncestr, // 支付簽名隨機串,不長於 32 位
                        package: "prepay_id=" param.transNo, // 統一支付接口返回的prepay_id參數值,提交格式如:prepay_id=***)
                        signType: "MD5", // 簽名方式,默認爲´SHA1´,使用新版支付需傳入´MD5´
                        paySign: param.sign, // 支付簽名
                        success: function (res) {
                            if(res.errMsg == "chooseWXPay:ok"){
                                //alert("支付成功");
                                window.location.href  = "/hims/weixin/pages/Order_ok.html?access_token=" getUrlParam("access_token");
                            }else{
                                alert(res.errMsg);
                            }
                        },
                        cancel: function(res){
                            //alert(´取消支付´);
                        }
                    });
                }
            }   
        },
        error:function(data){
            var msg =  data.message || data.status;
            $.alert(´服務器錯誤´ msg);
        }
    });   
    return false;
});

獲取url代碼json

function getUrlParam(name){
    //構造一個含有目標參數的正則表達式對象
    var reg = new RegExp("(^|&)"  name  "=([^&]*)(&|$)");
    //匹配目標參數
    var r = window.location.search.substr(1).match(reg);
    //返回參數值
    if (r!=null) return unescape(r[2]); return null;
} 
相關文章
相關標籤/搜索