http://blog.csdn.net/wangsf789/article/details/53419781javascript
最近開發微信小程序進入到支付階段,一直以來從事App開發,因此支付流程仍是熟記於心的。可是微信小程序的支付就有點奇怪了,應用的建立是在公衆號裏,可是文檔的介紹卻在公衆號中沒法找到直接入口,甚是不解,並且小程序的師傅究竟是屬於公衆號支付範疇仍是app支付範疇也成疑問。下面是小程序支付文檔的入口(嵌套在小程序api中):php
小程序支付步驟:
1,預支付
2,根據預支付數據+簽名——>發起支付
3,支付回調
下面對這3個步驟進行簡單描述:
1,預支付。該接口經過前端提交需支付的信息(訂單號、價格等)給開發者服務器,開發者服務器在提交到微信,然後返回真正前端須要進行支付的一些信息;eg:
開發者服務器的預支付接口:
https://()htm?
total_fee=100&cid=6001&orderCodes=2016120119
{
"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 ,並且放在第一個)html
- wx.requestPayment({
- nonceStr: res.data.nonceStr,
- package: "prepay_id="+res.data.prepayId,
- signType: 'MD5',
- timeStamp: res.data.timestamp,
- paySign: sign,
- success: function(res){
- console.log("支付成功");
- },
- fail: function() {
- },
- complete: function() {
- }
- })
生成簽名sign
微信小程序
MD5加密工具下載地址:https://code.csdn.net/snippets/2019875/master/download
- var MD5Util = require('../../../utils/md5.js');
- var sign = '';
- 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();
生成簽名上面是個人代碼,不是很清晰, 下面列出來官方文檔的詳細描述:
假設傳送的參數以下:
appid: wxd930ea5d5a258f4f(須要注意的是appid 在wx.requestPayment({})發起支付是不上傳,可是簽名時須要)
mch_id: 10000100
device_info: 1000
body: test
nonce_str: ibuaiVcKdpRxkhJA
第一步:對參數按照key=value的格式,並按照參數名ASCII字典序排序以下:
stringA="appid=wxd930ea5d5a258f4f&body=test&device_info=1000&mch_id=10000100&nonce_str=ibuaiVcKdpRxkhJA";
第二步:拼接API密鑰:
stringSignTemp="stringA&key=192006250b4c09247ec02edce69f6a2d"
sign=MD5(stringSignTemp).toUpperCase()="9A0A8659F005D6984697E2CA0A9CF3B7"
此時的sign 用於wx.requestPayment 上傳參數paySign。
最終獲得最終發送的數據:
- <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>
OK, 微信小程序支付完成。66666