這篇文章主要介紹“怎么封裝微信小程序http攔截器”的相關(guān)知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“怎么封裝微信小程序http攔截器”文章能幫助大家解決問題。
成都創(chuàng)新互聯(lián)是工信部頒發(fā)資質(zhì)IDC服務(wù)器商,為用戶提供優(yōu)質(zhì)的四川雅安電信機房服務(wù)第一步:創(chuàng)建一個request.js文件
第二步:確定http、upload和websocket前綴
第三步:封裝wx.request
在請求發(fā)出前處理http地址、請求頭和參數(shù)、在響應(yīng)后解析返回值并做基本的邏輯判斷,重點是使用Promise對象。
第四步:導出模塊
第五步:使用request
const Request = require("/utils/request");//導入模塊 Request.post("/api/xcxWxLogin", { //調(diào)用方法 code: res.code, encryptedData: resp.encryptedData, iv: resp.iv, shareId: share.shareId || "", salesmanId: share.salesmanId || "", source: share.source || "" }).then(res => { //成功回調(diào) //todo }).catch(err => {}); //異?;卣{(diào)
第六步:攔截器完整代碼
const apiHttp = "https://*****.com"; const socketHttp = "wss://*****.com/wss"; function fun(url, method, data, header) { data = data || {}; header = header || {}; let sessionId = wx.getStorageSync("UserSessionId"); if (sessionId) { if (!header || !header["SESSIONID"]) { header["SESSIONID"] = sessionId; } } wx.showNavigationBarLoading(); let promise = new Promise(function(resolve, reject) { wx.request({ url: apiHttp + url, header: header, data: data, method: method, success: function(res) { if (typeof res.data === "object") { if (res.data.status) { if (res.data.status === -200) { wx.showToast({ title: "為確保能向您提供最準確的服務(wù),請退出應(yīng)用重新授權(quán)", icon: "none" }); reject("請重新登錄"); } else if (res.data.status === -201) { wx.showToast({ title: res.data.msg, icon: "none" }); setTimeout(function() { wx.navigateTo({ url: "/pages/user/supplement/supplement" }); }, 1000); reject(res.data.msg); } } } resolve(res); }, fail: reject, complete: function() { wx.hideNavigationBarLoading(); } }); }); return promise; } function upload(url, name, filePath) { let header = {}; let sessionId = wx.getStorageSync("UserSessionId"); //從緩存中拿該信息 if (sessionId) { if (!header || !header["SESSIONID"]) { header["SESSIONID"] = sessionId; //添加到請求頭中 } } wx.showNavigationBarLoading(); let promise = new Promise(function(resolve, reject) { wx.uploadFile({ url: apiHttp + url, filePath: filePath, name: name, header: header, success: function(res) { resolve(res); }, fail: reject, complete: function() { wx.hideNavigationBarLoading(); } }); }); return promise; } module.exports = { apiHttp: apiHttp, socketHttp: socketHttp, "get": function(url, data, header) { return fun(url, "GET", data, header); }, "post": function(url, data, header) { return fun(url, "POST", data, header); }, upload: function(url, name, filePath) { return upload(url, name, filePath); } };
關(guān)于“怎么封裝微信小程序http攔截器”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,小編每天都會為大家更新不同的知識點。