微信小程序進(jìn)行微信支付的示例分析

小編給大家分享一下微信小程序進(jìn)行微信支付的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

成都網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)!專(zhuān)注于網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)公司、微信開(kāi)發(fā)、小程序設(shè)計(jì)、集團(tuán)成都定制網(wǎng)頁(yè)設(shè)計(jì)等服務(wù)項(xiàng)目。核心團(tuán)隊(duì)均擁有互聯(lián)網(wǎng)行業(yè)多年經(jīng)驗(yàn),服務(wù)眾多知名企業(yè)客戶;涵蓋的客戶類(lèi)型包括:成都公路鉆孔機(jī)等眾多領(lǐng)域,積累了大量豐富的經(jīng)驗(yàn),同時(shí)也獲得了客戶的一致贊美!

最近開(kāi)發(fā)微信小程序進(jìn)入到支付階段,一直以來(lái)從事App開(kāi)發(fā),所以支付流程還是熟記于心的。下面通過(guò)本文給大家講述下微信小程序進(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)行微信支付的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

網(wǎng)站題目:微信小程序進(jìn)行微信支付的示例分析
瀏覽地址:http://bm7419.com/article12/pcdpgc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站收錄、電子商務(wù)、、定制開(kāi)發(fā)靜態(tài)網(wǎng)站、用戶體驗(yàn)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化