前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >微信小程序充值操作流程

微信小程序充值操作流程

原创
作者头像
疯狂的小程序
发布2018-01-25 17:51:04
6.7K0
发布2018-01-25 17:51:04
举报
文章被收录于专栏:疯狂的小程序疯狂的小程序

微信小程序的充值流程与 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) { }

})

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 比如说页面上有一个充值按钮,点击充值按钮时可以获取到用户请求充值的参数。  
  • 2. 调用 wx.requestPayment 唤起微信支付界面。
相关产品与服务
云开发 CloudBase
云开发(Tencent CloudBase,TCB)是腾讯云提供的云原生一体化开发环境和工具平台,为200万+企业和开发者提供高可用、自动弹性扩缩的后端云服务,可用于云端一体化开发多种端应用(小程序、公众号、Web 应用等),避免了应用开发过程中繁琐的服务器搭建及运维,开发者可以专注于业务逻辑的实现,开发门槛更低,效率更高。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档