|
導讀微信小程序,簡稱小程序,英文名Mini Program,是一種不需要下載安裝即可使用的應用,它實現了應用“觸手可及”的夢想,用戶掃一掃或搜一下即可打開應用。小程序是一種不用下載就能使用的應用,也是一... 微信小程序,簡稱小程序,英文名Mini Program,是一種不需要下載安裝即可使用的應用,它實現了應用“觸手可及”的夢想,用戶掃一掃或搜一下即可打開應用。小程序是一種不用下載就能使用的應用,也是一項門檻非常高的創新,經過將近兩年的發展,已經構造了新的小程序開發環境和開發者生態。 最近開發微信小程序進入到支付階段,一直以來從事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: 開發者服務器的預支付接口: 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 ,而且放在第一個) wx.requestPayment({
nonceStr: res.data.nonceStr,
package: "prepay_id="+res.data.prepayId,
signType: 'MD5',
timeStamp: res.data.timestamp,
paySign: sign,//<strong><span style="color:#ff0000;">五個字段參與簽名(區分大小寫):appId,nonceStr,package,signType,timeStamp(需要注意的是,這5個參數簽名排序的順序按照ASCII字典序排序)</span></strong>
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.net/snippets/2019875/master/download var MD5Util = require('../../../utils/md5.js');
var sign = '';
//<strong><span style="color:#ff0000;">順序按照ASCII字典序排序</span></strong>
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> 以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP中文網! 相關推薦: 以上就是關于微信小程序進行微信支付的步驟的詳細內容,更多請關注php中文網其它相關文章! 小程序是一種不需要下載安裝即可使用的應用,它實現了應用“觸手可及”的夢想,用戶掃一掃或者搜一下即可打開應用。 |
溫馨提示:喜歡本站的話,請收藏一下本站!