微信小程序支付包含uniapp方法超詳細講解
本文只介紹前端的實現(xiàn)邏輯,所以不涉及申請微信支付API,因為該功能是后端處理。
一、了解微信支付流程
官方參考文檔:微信支付開發(fā)文檔
微信支付官方流程圖:

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

代碼示例:
// uniapp || 微信小程序
PlaceAnOrder(params).then((res) => {
const PayParams = { order_id: res.order_id }; // 接口返回的訂單ID
})
2.獲取支付參數(shù)
通過訂單id調(diào)用后端接口拿到支付參數(shù)(后端調(diào)用預支付接口的時候拿到的參數(shù)):appId、timeStamp、nonceStr、package、signType,不過要區(qū)別uniapp的寫法,和官方大有不同
| 字段名 | 變量名 | 必填 | 類型 | 示例值 | 描述 |
|---|---|---|---|---|---|
| 小程序ID | appId | 是 | String | wxd678efh567hg6787 | 微信分配的小程序ID |
| 時間戳 | timeStamp | 是 | String | 1490840662 | 時間戳從1970年1月1日00:00:00至今的秒數(shù),即當前的時間 |
| 隨機串 | nonceStr | 是 | String | 5K8264ILTKCH16CQ2502SI8ZNMTM67VS | 隨機字符串,不長于32位。推薦隨機數(shù)生成算法 |
| 數(shù)據(jù)包 | package | 是 | String | prepay_id=wx2017033010242291fcfe0db70013231072 | 統(tǒng)一下單接口返回的 prepay_id 參數(shù)值,提交格式如:prepay_id=wx2017033010242291fcfe0db70013231072 |
| 簽名方式 | signType | 是 | String | MD5 | 簽名類型,默認為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ā)起微信支付
當一切參數(shù)都能拿到并且準確無誤后調(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)
總結
到此這篇關于微信小程序支付包含uniapp方法的文章就介紹到這了,更多相關微信小程序支付包含uniapp內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
IE與FF下javascript獲取網(wǎng)頁及窗口大小的區(qū)別詳解
本篇文章主要是對IE與FF下javascript獲取網(wǎng)頁及窗口大小的區(qū)別進行了詳細的介紹,需要的朋友可以過來參考下,希望對大家有所幫助2014-01-01

