137-3385-8848(同微信)

微信小程序充值页面及小程序支付后回调如何实现

2022-04-21 管理员
class="output_wrapper" id="output_wrapper_id">

微信小程序的充值流程与 H5 或 公众号大致差不多,这里简单说一下前端在充值时候的一些操作流程。

用户在小程序中发起充值请求时,一般会先请求自己的服务器,将充值的参数发送给后端,然后后端会去请求微信充值,得到微信返回的统一下单的参数再返回给前端。前端调用

wx.requestPayment API 即可唤起微信小程序的支付页面,此时用户输入正确的支付密码即可支付成功。具体流程如下:

1. 比如说页面上有一个充值按钮,点击充值按钮时可以获取到用户请求充值的参数。  

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  // 后端从微信得到的统一下单的参数
       })
       that.xcxPay();  // 拿到统一下单的参数后唤起微信支付页面
     } 
   }
})

 

2. 调用 wx.requestPayment 唤起微信支付界面。
wx.requestPayment({
   'timeStamp': that.data.payParams.timestamp.toString(),  // 时间戳必须是字符串,否则会报错
   'nonceStr': that.data.payParams.str,
   'package': 'prepay_id=' + that.data.payParams.prepay_id,  // 这里的值必须是 prepay_id=XXXXXXXXX 的格式,否则也会报错
   'signType': 'MD5',
   'paySign': that.data.payParams.sign,
   'success': function (res) { 
    // 这里应该是 res.errMsg , 跟公众号的支付返回的参数不一样,公众号是 err_msg, 就因为没注意到这个,折腾了很长时间
     if(res.errMsg == "requestPayment:ok"){  // 调用支付成功
        wx.redirectTo({
              url: '../chargelist/chargelist'   // 充值成功后的处理,可以跳转,也可以根据自己的需要做其他处理
         })
      }else if(res.errMsg == 'requestPayment:cancel'){
      // 用户取消支付的操作
    }
   },
   'fail': function (res) {
     return false;
   },
   'complete': function (res) { }
})

小程序工具提供多类型商城/门店小程序制作,可视化编辑 1秒生成5步上线。通过拖拽、拼接模块布局小程序商城页面,所看即所得,只需要美工就能做出精美商城。

更多微信小程序相关资讯,请前往:https://www.kesion.com/miniprogramschool/

上一篇:H5与小程序如何共用的一套代码
下一篇:微信小程序小游戏转发其他用户或群聊,小程序转化获得转发信息
相关资讯 Releva ntnews
解决方案 Solutions
相关热点 Hot spot
郑州做排名中正确使用关键词优化的方法
  1. 我们的优势
  2. 我们的实力
  3. 选择我们的理由
咨询电话(微信同号)

137-3385-8848(同微信)

豫ICP备16014343号-1

Copyright © 2017-2022 版权所有 酷微科技 Rights Reserved

电话咨询 在线咨询 服务项目 SEO优化