最近在做支付功能,微信支付准备工作之类的请参考官方说明,注意个人申请的测试号不支持,要申请企业号,还要商户号,开通支付权限,配置域名,JSSDK的权限问题,尽可能都开通吧!
官方地址可参考这里:接入准备工作
这里大概说一下前端要做的,项目先引入微信jssdk,安装依赖,
npm install weixin-js-sdk --save
main.js引入,设置成全局属性,也可以设置成局部属性,那当前页引入就好了,
import wx from 'weixin-js-sdk'
Vue.use(wx);
Vue.prototype.$wx = wx
先是微信登录授权,获取code传给后台,拿到用户信息,之前有写过,这里不做说明了====
大概说一下前端要做的事情,大概逻辑是:用户下单->选择微信支付->提交订单,
// 提交订单
this.$http.get(`/xxx/xxx/xxx/pay/`)
.then(async res=> {
console.log('返回的支付res:',res);
console.log('是否微信浏览器====',isWechat);
if(isWechat&&json.payType === 'WECHAT_PAY') {
console.log('微信公众号内-微信支付===============');
this.wechatPayFunction(res.pay) // 微信公众号支付
}
......
})
这里后端返回的数据大概是这样:
记得要先通过后端接口获取到微信公众号的配置信息,返回的数据格式大概是这样:
微信配置成功之后,就可以使用微信自带的wx.chooseWXPay发起微信支付请求啦!
官方文档可参考这里:微信支付
上代码:
// 微信公众号内微信支付方法
async wechatPayFunction(payData) {
let that = this;
let url = window.location.href.split('#')[0];
await this.$http.get(`/api/wechat/jssdk?url=`+url).then(res=>{
console.log('微信config', res);
// 配置config信息
wx.config({
debug: false,
appId: res.appId, // 必填,公众号的唯一标识
timestamp: res.timestamp, // 必填,生成签名的时间戳
nonceStr: res.nonceStr, // 必填,生成签名的随机串
signature: res.signature, // 必填,签名
jsApiList: ['checkJsApi', 'chooseWXPay'] // 必填,需要使用的JS接口列表
});
// 通过ready接口处理成功验证
wx.ready(function () {
wx.checkJsApi({
jsApiList: ['chooseWXPay'],
success: function (res) {
console.log('微信config检验成功',res);
}
});
wx.chooseWXPay({
timestamp: payData.timeStamp, // 支付签名时间戳,注意微信 jssdk 中的所有使用 timestamp 字段均为小写。但最新版的支付后台生成签名使用的 timeStamp 字段名需大写其中的 S 字符
nonceStr: payData.nonceStr, // 支付签名随机串,不长于 32 位
package: payData.package, // 统一支付接口返回的prepay_id参数值,提交格式如:prepay_id=\*\*\*)
signType: payData.signType, // 微信支付V3的传入 RSA ,微信支付V2的传入格式与V2统一下单的签名格式保持一致
paySign: payData.paySign, // 支付签名
success: function (res) { // 支付成功后的回调函数
console.log('支付成功=============' + res)
},
fail: function (res) {
console.log('支付失败===============' + res)
}
});
});
});
需要注意的问题:
1、调取微信支付前需要先获取到微信config信息,用后台返回的参数注入当前权限,才可以正常调用wx.chooseWXPay;
2、wx.chooseWXPay需要的参数通过支付接口再返回给前端,再发起微信支付请求;
3、注意一下参数大小写,核实后台接口返的和前端是否一致,因为本地不方便调试,每次都要发到服务器上,耽误了好久;还有因为也做了APP内的微信支付,一开始跟APP微信支付的后端接口返回参数搞错了,报错原因也查了很久,总之细心一点再细心一点,测试通过了还是很开心的,哈哈哈==;