最近开发微信小程序进入到支付阶段,一直以来从事App开发,所以支付流程还是熟记于心的。但是微信小程序的支付就有点奇怪了,应用的创建是在公众号里,但是文档的介绍却在公众号中无法找到直接入口,甚是不解,而且小程序的师傅到底是属于公众号支付范畴还是app支付范畴也成疑问。下面是小程序支付文档的入口(嵌套在小程序api中):
小程序支付步骤:
1,预支付
2,根据预支付数据+签名——>发起支付
3,支付回调
下面对这3个步骤进行简单描述:
1,预支付。
该接口通过前端提交需支付的信息(订单号、价格等)给开发者服务器,开发者服务器在提交到微信,而后返回真正前端需要进行支付的一些信息;eg:开发者服务器的预支付接口:
2,发起支付(需要注意的是发起支付是不需要上传appid,
但是签名paySign需要appid,而且放在第一个)
success: function(res){
console.log("支付成功");
},fail: function() {
},complete: function() {
}
})
生成签名sign
微信小程序MD5加密工具下载地址:https://code.csdn.net/snippets/2019875/master/download
var signA = "appId="+app.appId+"&nonceStr="+res.data.nonceStr+"&package=prepay_id="+res.data.prepayId+"&signType=MD5&timeStamp="+res.data.timestamp;
var signB = signA+"&key="+app.key;
sign = MD5Util.MD5(signB).toUpperCase();
生成签名上面是我的代码,不是很清晰, 下面列出来官方文档的详细描述:
假设传送的参数如下:
上传,但是签名时需要)
mch_id: 10000100
device_info: 1000
body: test
nonce_str: ibuaiVcKdpRxkhJA
第一步:对参数按照key=value的格式,并按照参数名ASCII字典序排序如下:
第二步:拼接API密钥:
此时的sign 用于wx.requestPayment 上传参数paySign。
最终得到最终发送的数据:
以上所述是小编给大家介绍的微信小程序进行微信支付的步骤。编程之家 jb51.cc 收集整理的教程希望能对你有所帮助,如果觉得编程之家不错,可分享给好友!感谢支持。