小程序模板網(wǎng)

微信小程序充值及充值回調(diào)后的處理

發(fā)布時(shí)間:2018-05-03 15:56 所屬欄目:小程序開發(fā)教程

微信小程序的充值流程與 H5 或 公眾號大致差不多,這里簡單說一下前端在充值時(shí)候的一些操作流程。

用戶在小程序中發(fā)起充值請求時(shí),一般會(huì)先請求自己的服務(wù)器,將充值的參數(shù)發(fā)送給后端,然后后端會(huì)去請求微信充值,得到微信返回的統(tǒng)一下單的參數(shù)再返回給前端。前端調(diào)用

wx.requestPayment API 即可喚起微信小程序的支付頁面,此時(shí)用戶輸入正確的支付密碼即可支付成功。具體流程如下:

1. 比如說頁面上有一個(gè)充值按鈕,點(diǎn)擊充值按鈕時(shí)可以獲取到用戶請求充值的參數(shù)?! ?/h2>
wx.request({
  url: "后端的充值接口",
   method: "POST",
   dataType: "json",
   header: {
     'content-type': 'application/x-www-form-urlencoded'
   },
   data: {
     amount: amount,  // 充值金額
     token: token,
     openId: openId
   },
   success: function (res) {
     if (res.data.code == '1') {
       that.setData({
         payParams: res.data.data  // 后端從微信得到的統(tǒng)一下單的參數(shù)
       })
       that.xcxPay();  // 拿到統(tǒng)一下單的參數(shù)后喚起微信支付頁面
     } 
   }
})

2. 調(diào)用 wx.requestPayment 喚起微信支付界面。

wx.requestPayment({
   'timeStamp': that.data.payParams.timestamp.toString(),  // 時(shí)間戳必須是字符串,否則會(huì)報(bào)錯(cuò)
   'nonceStr': that.data.payParams.str,
   'package': 'prepay_id=' + that.data.payParams.prepay_id,  // 這里的值必須是 prepay_id=XXXXXXXXX 的格式,否則也會(huì)報(bào)錯(cuò)
   'signType': 'MD5',
   'paySign': that.data.payParams.sign,
   'success': function (res) { 
    // 這里應(yīng)該是 res.errMsg , 跟公眾號的支付返回的參數(shù)不一樣,公眾號是 err_msg, 就因?yàn)闆]注意到這個(gè),折騰了很長時(shí)間
     if(res.errMsg == "requestPayment:ok"){  // 調(diào)用支付成功
        wx.redirectTo({
              url: '../chargelist/chargelist'   // 充值成功后的處理,可以跳轉(zhuǎn),也可以根據(jù)自己的需要做其他處理
         })
      }else if(res.errMsg == 'requestPayment:cancel'){
      // 用戶取消支付的操作
    }
   },
   'fail': function (res) {
     return false;
   },
   'complete': function (res) { }
}) 

 
 
 


易優(yōu)小程序(企業(yè)版)+靈活api+前后代碼開源 碼云倉庫:starfork
本文地址:http://www.u-renovate.com/wxmini/doc/course/24215.html 復(fù)制鏈接 如需定制請聯(lián)系易優(yōu)客服咨詢:800182392 點(diǎn)擊咨詢
QQ在線咨詢
AI智能客服 ×