最近开发微信小程序进入到支付阶段,一直以来从事app开发,所以支付流程还是熟记于心的。下面通过本文给大家讲述下微信小程序进行微信支付的步骤,需要的朋友可以参考下
最近开发微信小程序进入到支付阶段,一直以来从事App开发,所以支付流程还是熟记于心的。但是微信小程序的支付就有点奇怪了,应用的创建是在公众号里,但是文档的介绍却在公众号中无法找到直接入口,甚是不解,而且小程序的师傅到底是属于公众号支付范畴还是app支付范畴也成疑问。下面是小程序支付文档的入口(嵌套在小程序api中):
https://pay.weixin.qq.com/wiki/doc/api/wxa/wxa_api.php?chapter=7_3&index=1
小程序支付步骤:
1,预支付
2,根据预支付数据+签名——>发起支付
3,支付回调
下面对这3个步骤进行简单描述:
1,预支付。该接口通过前端提交需支付的信息(订单号、价格等)给开发者服务器,开发者服务器在提交到微信,而后返回真正前端需要进行支付的一些信息;eg:
开发者服务器的预支付接口:
1 2 3 4 5 6 7 8 9 10 | https:
{
"sign" : "A2****************A6" ,
"timestamp" : "14****************68" ,
"package" : "Sign=WXPay" ,
"partnerId" : "14****************02" ,
"appid" : "wx****************ab" ,
"nonceStr" : "9f****************37" ,
"prepayId" : "wx****************54"
}
|
2,发起支付(需要注意的是发起支付是不需要上传appid,
但是签名paySign需要appid ,而且放在第一个)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | wx.requestPayment({
nonceStr: res.data.nonceStr,
package: "prepay_id=" +res.data.prepayId,
signType: & #39;MD5',
timeStamp: res.data.timestamp,
paySign: sign,
success: function (res){
console.log( "支付成功" );
},
fail: function () {
},
complete: function () {
}
})
|
生成签名sign
https://pay.weixin.qq.com/wiki/doc/api/wxa/wxa_api.php?chapter=7_3&index=1&t=20161122
微信小程序MD5加密工具-:https://code.csdn-/snippets/2019875/master/download
1 2 3 4 5 6 | var MD5Util = require(& #39;../../../utils/md5.js');
var sign = & #39;';
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();
|
生成签名上面是我的代码,不是很清晰, 下面列出来官方文档的详细描述:
假设传送的参数如下:
1 2 3 4 5 | appid: wxd930ea5d5a258f4f(需要注意的是appid 在wx.requestPayment({})发起支付是不上传,但是签名时需要)
mch_id: 10000100
device_info: 1000
body: test
nonce_str: ibuaiVcKdpRxkhJA
|
第一步:对参数按照key=value的格式,并按照参数名ASCII字典序排序如下:
1 | stringA= "appid=wxd930ea5d5a258f4f&body=test&device_info=1000&mch_id=10000100&nonce_str=ibuaiVcKdpRxkhJA" ;
|
第二步:拼接API密钥:
1 2 | stringSignTemp= "stringA&key=192006250b4c09247ec02edce69f6a2d"
sign=MD5(stringSignTemp).toUpperCase()= "9A0A8659F005D6984697E2CA0A9CF3B7"
|
此时的sign 用于wx.requestPayment 上传参数paySign。
最终得到最终发送的数据:
1 2 3 4 5 6 7 8 | <xml>
<appid>wxd930ea5d5a258f4f</appid>
<mch_id>10000100</mch_id>
<device_info>1000<device_info>
<body>test</body>
<nonce_str>ibuaiVcKdpRxkhJA</nonce_str>
<sign>9A0A8659F005D6984697E2CA0A9CF3B7</sign>
<xml>
|
以上就是本文的全部内容,希望对大家的学习有所帮助。
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
暂时没有评论,来抢沙发吧~