微信小程序進(jìn)行微信支付的步驟昂述
最近開(kāi)發(fā)微信小程序進(jìn)入到支付階段,一直以來(lái)從事App開(kāi)發(fā),所以支付流程還是熟記于心的。但是微信小程序的支付就有點(diǎn)奇怪了,應(yīng)用的創(chuàng)建是在公眾號(hào)里,但是文檔的介紹卻在公眾號(hào)中無(wú)法找到直接入口,甚是不解,而且小程序的師傅到底是屬于公眾號(hào)支付范疇還是app支付范疇也成疑問(wèn)。下面是小程序支付文檔的入口(嵌套在小程序api中):
https://pay.weixin.qq.com/wiki/doc/api/wxa/wxa_api.php?chapter=7_3&index=1
小程序支付步驟:
1,預(yù)支付
2,根據(jù)預(yù)支付數(shù)據(jù)+簽名——>發(fā)起支付
3,支付回調(diào)
下面對(duì)這3個(gè)步驟進(jìn)行簡(jiǎn)單描述:
1,預(yù)支付。該接口通過(guò)前端提交需支付的信息(訂單號(hào)、價(jià)格等)給開(kāi)發(fā)者服務(wù)器,開(kāi)發(fā)者服務(wù)器在提交到微信,而后返回真正前端需要進(jìn)行支付的一些信息;eg:
開(kāi)發(fā)者服務(wù)器的預(yù)支付接口:
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,發(fā)起支付(需要注意的是發(fā)起支付是不需要上傳appid,
但是簽名paySign需要appid ,而且放在第一個(gè))
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;">五個(gè)字段參與簽名(區(qū)分大小寫(xiě)):appId,nonceStr,package,signType,timeStamp(需要注意的是,這5個(gè)參數(shù)簽名排序的順序按照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();
生成簽名上面是我的代碼,不是很清晰, 下面列出來(lái)官方文檔的詳細(xì)描述:
假設(shè)傳送的參數(shù)如下:
appid: wxd930ea5d5a258f4f(需要注意的是appid 在wx.requestPayment({})發(fā)起支付是不上傳,但是簽名時(shí)需要)
mch_id: 10000100
device_info: 1000
body: test
nonce_str: ibuaiVcKdpRxkhJA
第一步:對(duì)參數(shù)按照key=value的格式,并按照參數(shù)名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"
此時(shí)的sign 用于wx.requestPayment 上傳參數(shù)paySign。
最終得到最終發(fā)送的數(shù)據(jù):
<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>
以上所述是小編給大家介紹的微信小程序進(jìn)行微信支付的步驟,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
JavaScript使用Base64編碼和Blob對(duì)象加密圖像url地址
有時(shí)候會(huì)看到一些網(wǎng)站的圖片src中是blob:http://example.com/7c672acb-375c-4a26-9af9-99cb4c77f04d,這樣的圖片加載怎么實(shí)現(xiàn)呢?本文講解在瀏覽器中JavaScript使用解析Base64編碼和Blob對(duì)象技術(shù)來(lái)實(shí)現(xiàn),下面是實(shí)現(xiàn)的步驟和相應(yīng)的示例代碼,2023-12-12
前端URL拼接路徑參數(shù)具體實(shí)現(xiàn)代碼
這篇文章主要給大家介紹了關(guān)于前端URL拼接路徑參數(shù)具體實(shí)現(xiàn)的相關(guān)資料,url地址拼接是經(jīng)常會(huì)遇到的問(wèn)題,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-12-12
JS實(shí)現(xiàn)鼠標(biāo)點(diǎn)擊箭頭旋轉(zhuǎn)180度功能
這篇文章主要介紹了JS實(shí)現(xiàn)鼠標(biāo)點(diǎn)擊箭頭旋轉(zhuǎn)180度的效果,通過(guò)點(diǎn)擊三角按鈕旋轉(zhuǎn)180度,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧2024-02-02
js保留兩位小數(shù)最簡(jiǎn)單的實(shí)現(xiàn)方法
JS數(shù)據(jù)格式化是在進(jìn)行web前端開(kāi)發(fā)時(shí)常碰到的事情,特別是在數(shù)據(jù)類(lèi)型為Float的數(shù)據(jù)就需要特殊處理,如保留兩位小數(shù)、小數(shù)點(diǎn)后的數(shù)據(jù)是否需要四舍五入等等,下面這篇文章主要給大家介紹了關(guān)于js保留兩位小數(shù)最簡(jiǎn)單的實(shí)現(xiàn)方法,需要的朋友可以參考下2023-05-05

