微信小程序支付包含uniapp方法超詳細(xì)講解
本文只介紹前端的實(shí)現(xiàn)邏輯,所以不涉及申請微信支付API,因?yàn)樵摴δ苁呛蠖颂幚怼?/p>
一、了解微信支付流程
官方參考文檔:微信支付開發(fā)文檔
微信支付官方流程圖:

二、【前端】微信支付實(shí)現(xiàn)步驟
1.創(chuàng)建訂單接口
當(dāng)用戶點(diǎn)擊購買按鈕時(shí),首先第一步要?jiǎng)?chuàng)建訂單,后端需要提供下單接口(后端調(diào)用統(tǒng)一下單接口,也就是生成預(yù)支付交易單),該接口返回給前端一個(gè)訂單id,此時(shí)訂單處于待付款狀態(tài)

代碼示例:
// uniapp || 微信小程序
PlaceAnOrder(params).then((res) => {
const PayParams = { order_id: res.order_id }; // 接口返回的訂單ID
})
2.獲取支付參數(shù)
通過訂單id調(diào)用后端接口拿到支付參數(shù)(后端調(diào)用預(yù)支付接口的時(shí)候拿到的參數(shù)):appId、timeStamp、nonceStr、package、signType,不過要區(qū)別uniapp的寫法,和官方大有不同
| 字段名 | 變量名 | 必填 | 類型 | 示例值 | 描述 |
|---|---|---|---|---|---|
| 小程序ID | appId | 是 | String | wxd678efh567hg6787 | 微信分配的小程序ID |
| 時(shí)間戳 | timeStamp | 是 | String | 1490840662 | 時(shí)間戳從1970年1月1日00:00:00至今的秒數(shù),即當(dāng)前的時(shí)間 |
| 隨機(jī)串 | nonceStr | 是 | String | 5K8264ILTKCH16CQ2502SI8ZNMTM67VS | 隨機(jī)字符串,不長于32位。推薦隨機(jī)數(shù)生成算法 |
| 數(shù)據(jù)包 | package | 是 | String | prepay_id=wx2017033010242291fcfe0db70013231072 | 統(tǒng)一下單接口返回的 prepay_id 參數(shù)值,提交格式如:prepay_id=wx2017033010242291fcfe0db70013231072 |
| 簽名方式 | signType | 是 | String | MD5 | 簽名類型,默認(rèn)為MD5,支持HMAC-SHA256和MD5。注意此處需與統(tǒng)一下單的簽名類型一致 |
// 微信開發(fā)工具
PlaceAnOrder(params).then((res) => {
const wxPayParams = {
order_id: res.data.order_id,
};
fetchWxPay(wxPayParams).then((payRes) => {
const { data } = payRes; // data包含了appId、timeStamp、nonceStr、package、signType,后端已對格式做處理,格式參考上面表格
const payData = {
...data,
success(sucRes) {
console.log('success', sucRes);
},
fail(err) {
console.log('err', err);
},
complete() {
console.log('complete');
},
};
});
});
// uniapp
payApi(PayParams).then((payRes) => {
uni.getProvider({
service: 'payment',
success: function (res) {
let payConfing: any = {};
payConfing = {
provider: res.provider[0],
...payRes,
service: 5,
success(sucRes) {
console.log('success', sucRes);
},
fail(err) {
console.log('err', err);
},
complete() {
console.log('complete');
},
},
}
})
})
3.調(diào)用wx.requestPayment發(fā)起微信支付
當(dāng)一切參數(shù)都能拿到并且準(zhǔn)確無誤后調(diào)用微信官方接口wx.requestPayment,如果是uniapp則使用uni.requestPayment,具體參數(shù)說明參考:https://doc.dcloud.net.cn/uni-app-x/api/request-payment.html#requestpayment
// weixin wx.requestPayment(payData) // uniapp uni.requestPayment(payConfing)
總結(jié)
到此這篇關(guān)于微信小程序支付包含uniapp方法的文章就介紹到這了,更多相關(guān)微信小程序支付包含uniapp內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
IE與FF下javascript獲取網(wǎng)頁及窗口大小的區(qū)別詳解
本篇文章主要是對IE與FF下javascript獲取網(wǎng)頁及窗口大小的區(qū)別進(jìn)行了詳細(xì)的介紹,需要的朋友可以過來參考下,希望對大家有所幫助2014-01-01
微信小程序開發(fā)之全局配置與頁面配置實(shí)現(xiàn)
本文主要介紹了微信小程序開發(fā)之全局配置與頁面配置實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07
JavaScript兩個(gè)變量交換值的實(shí)現(xiàn)方法
本文主要介紹了JavaScript兩個(gè)變量交換值(不使用臨時(shí)變量)的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,下面跟著小編一起來看下吧2017-03-03
Javascript表格翻頁效果實(shí)現(xiàn)思路及代碼
表格翻頁的實(shí)現(xiàn)方式有很多,下面以js為例為大家詳細(xì)介紹下表格翻頁效果的具體實(shí)現(xiàn),感興趣的朋友可以參考下2013-08-08

