JavaScript

超轻量级php框架startmvc

小程序调用微信支付的方法

更新时间:2020-09-15 18:48:01 作者:startmvc
本文实例为大家分享了小程序调用微信支付的具体代码,供大家参考,具体内容如下首先调

本文实例为大家分享了小程序调用微信支付的具体代码,供大家参考,具体内容如下

首先调用小程序wx.login登录接口  获取用户code

将code作为参数  传给后端  调用后端接口wechat/pay/prepay

获取后端  这五个返回值

nonceStr  package2 paySign  signType timeStamp


wx.login({
 success: function (res) {
 var userId = wx.getStorageSync('userId');
 var passw = userId + orderId;
 console.log(passw)
 var password = util.sha1(passw);
 //console.log(res) //获取用户的code 微信返回的值 
 wx.request({
 url: url + 'wechat/pay/prepay',
 method: "POST",
 header: {
 'content-type': 'application/json',
 },
 data: {
 code: res.code, //微信返的code
 userId: userId, //登录注册时后端返给我的
 orderId: orderId, //用户提交时后端返给我的工单号
 sign: password, //后端要求的serId + orderId加密
 },
 success: function (res) {
 // if (res.data.resultCode == "000000"){
 nonceStr = res.data.data.nonceStr;
 package2 = res.data.data.package;
 paySign = res.data.data.paySign;
 signType = res.data.data.signType;
 timeStamp = res.data.data.timeStamp;
 that.pay2()
 // }
 console.log(res.data.data.nonceStr)
 console.log(res.data.data.package)
 console.log(res.data.data.paySign)
 console.log(res.data.data.signType)
 console.log(res.data.data.timeStamp)
 },
 fail(err) {
 console.log(err)
 }
 })
 },
 fail(errs) {
 console.log(errs)
 }
 })

成功返回后,用户点击支付,调用微信支付接口wx.requestPayment:

后端设置好金额,用户调用即可支付


pay2() {
 wx.requestPayment(
 {
 timeStamp: timeStamp, //时间戳
 nonceStr: nonceStr, //随机字符串
 package: package2, //统一下单接口返回的 prepay_id 参数值
 signType: signType, //签名类型
 paySign: paySign, //签名
 success(res) {
 console.log(res)
 wx.navigateTo({
 url: '../successful/successful'
 })
 },
 fail(res) {
 console.log(res)
 }
 })
 },

最后我们的项目在调用微信wx.requestPayment 支付接口时,在success成功函数里请求了我方后端接口,获取状态码,判断是否支付成功。因为用户支付给微信,成功之后,只有用户能够看到,我方后端是获取不到是否支付成功的,请求这个接口就是这个目的。在微信请求支付成功之后,请求后端获取返回值。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

小程序 微信支付