91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

微信小程序中網絡請求緩存怎么實現

發布時間:2022-04-18 17:21:23 來源:億速云 閱讀:125 作者:zzz 欄目:開發技術

這篇文章主要介紹“微信小程序中網絡請求緩存怎么實現”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“微信小程序中網絡請求緩存怎么實現”文章能幫助大家解決問題。

需求

提交小程序審核時,有一個體驗測評,產品讓我們根據小程序的體驗測評報告去優化小程序。

其中有一項是網絡請求的優化,給我們出了很大的難題。

文檔中是這樣解釋的:3分鐘以內同一個url請求不出現兩次回包大于128KB且一模一樣的內容

看到這個問題的時候,首先想到的是在響應頭上加上cache-control,經過測試發現小程序并不支持網路請求緩存。搜索發現官方明確答復,小程序不支持網絡請求緩存:wx.request不支持http緩存

既然官方不支持網絡請求緩存,那只能自己想辦法解決這個問題了。

先來看一下需求:3分鐘內,同一請求只能請求一次。

分析

分析:

  • 只需做GET請求的網絡緩存。

  • 緩存時間如何控制。

  • 做了緩存之后,如何知道3分鐘,這個請求在服務端數據有沒更新。

  • 提交GET請求前,先檢查本地有沒有緩存

前兩點比較好實現,雖然小程序不支持網絡請求緩存,但我們還是可以利用cache-control來實現這個功能。

首先網絡請求需不需要情緩存統一交給服務端去做,服務端在處理GET請求時,統一加上響應頭cache-control,如果需要緩存就用max-age=180,如果不需要做網絡請求就用no-cache。前端根據響應頭信息自己做前端緩存。

其中的難點是前端如何知道服務端數據有沒更新,如果服務端數據更新了,前端還是使用緩存這是有問題的。

經過一番思考后發現,前端提交數據后,相應的GET請求數據會更新,也就是說前端只要有數據提交,就應該把緩存清空。

這有一個難點,當前端提交數據時,前端是不知道哪些GET請求會因此更新數據,所以這個問題我們沒有解決,我的方法比較粗暴:只要前端提交了數據,就將所有緩存清空。這是一個治標不治本的問題。

實現

公司項目封裝了HTTP請求

攔截請求,如果是GET請求,檢查緩存,

  • 如果緩存沒過期,將緩存返回出去,不再發請求

  • 如果緩存過期,發請求

if (request.method.toLowerCase() === "get"){
 // param 請求信息
 const cache = this.handleCatchControl(request)
 if (!cache.isRequest)
 return this.listener.onApiResponse(request, 200, cache.data), sequence; //將緩存返回給對應的請求
}

緩存網絡請求

// param 響應頭,上下文,響應數據
this.setCatchControl(headers, context, response.data)

兩個工具函數

  • 處理網絡緩存

  • 設置網絡緩存

設置網絡請求

  1. GET請求緩存數據,其他請求清空數據

  2. 數據格式:

//如果同時發起多個`GET`請求,需要拼接之前緩存數據
ApiAgent.cacheData = Object.assign(ApiAgent.cacheData,{
 [context.request.url]: { //api
 data, //響應數據
 expireTime: Number(cacheControl.split("=")[1] + '000'), //過期時間
 cacheTime: new Date().getTime(), //緩存時間
 }
})
// param 響應頭,上下文,響應數據
setCatchControl(responseHeader: any, context: any, data: any) {
 if (context.request.method.toLowerCase() === "get") {
 const headers = HandleHeaders.get(responseHeader)
 const cacheControl = headers["cache-control"]
 if (cacheControl && cacheControl !== "no-cache") {
  ApiAgent.cacheData = Object.assign(ApiAgent.cacheData,{
  [context.request.url]: {
   data,
   expireTime: Number(cacheControl.split("=")[1] + '000'),
   cacheTime: new Date().getTime(),
  }
  })
 }
 } else {
 ApiAgent.cacheData = {}
 }
}

處理網絡緩存

  1. 判斷緩存是否存在

  2. 判斷緩存有沒過期,在設置緩存時,比對當前時間和緩存時間,是否小于失效時間

// param 請求信息
handleCatchControl(request): any {
 const cacheArr = ApiAgent.cacheData
 if (Object.keys(cacheArr).length === 0)
 return { isRequest: true }
 let cache = {}
 Object.keys(cacheArr).forEach(cacheArrKey => {
 if (cacheArrKey === request.url) {
  cache = cacheArr[cacheArrKey]
 }
 })
 const newDate = new Date().getTime()
 if (newDate - cache.cacheTime < expireTime){
 return { isRequest: false, data: cache.data }
 }
 return { isRequest: true}
}

響應頭全部變成小寫,在小程序中,無法確定響應頭的大小寫會導致報錯,所以統一處理響應頭

class HandleHeaders {
 static get(headers: { [key: string]: string }) {
 const headersData: any = {}
 Object.keys(headers).forEach(key => {
  headersData[key.toLowerCase()] = headers[key]
 })
 return headersData
 }
}

關于“微信小程序中網絡請求緩存怎么實現”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

伽师县| 南雄市| 双辽市| 定边县| 闸北区| 克东县| 夏津县| 马关县| 建瓯市| 蓬莱市| 莱阳市| 加查县| 神池县| 昌乐县| 牙克石市| 卫辉市| 扎鲁特旗| 博罗县| 广汉市| 鞍山市| 金寨县| 营口市| 遂溪县| 安福县| 什邡市| 肥乡县| 天峻县| 临夏市| 大新县| 梁山县| 香河县| 阿克| 天气| 城口县| 获嘉县| 湾仔区| 东乡族自治县| 枞阳县| 肃北| 江达县| 彰武县|