溫馨提示×

溫馨提示×

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

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

微信小程序怎么實(shí)現(xiàn)本地?cái)?shù)據(jù)存儲

發(fā)布時間:2022-04-13 14:47:36 來源:億速云 閱讀:2071 作者:iii 欄目:編程語言

這篇“微信小程序怎么實(shí)現(xiàn)本地?cái)?shù)據(jù)存儲”文章的知識點(diǎn)大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“微信小程序怎么實(shí)現(xiàn)本地?cái)?shù)據(jù)存儲”文章吧。

微信小程序 本地?cái)?shù)據(jù)存儲實(shí)例詳解

前言

如果您在看此文章之前有過其他程序的開發(fā)經(jīng)驗(yàn),那一定會知道一般例如安卓或者蘋果的原生APP都提供了本地的存儲功能,甚至可以使用sqlite數(shù)據(jù)庫來做存儲??墒俏⑿诺男〕绦蚩蚣芑谖⑿疟旧恚鋵?shí)際運(yùn)行環(huán)境只是在瀏覽器里面,所以不會提供那么豐富的數(shù)據(jù)存儲實(shí)力。但html5開始已經(jīng)可以在瀏覽器里面存儲數(shù)據(jù),好在微信的小程序給這個功能封裝好了,這樣我們可以使用數(shù)據(jù)存儲。

每個微信小程序都可以有自己的本地緩存,可以通過 wx.setStorage(wx.setStorageSync)

wx.getStorage(wx.getStorageSync)、 
wx.clearStorage(wx.clearStorageSync)

可以對本地緩存進(jìn)行設(shè)置、獲取和清理。本地緩存最大為10MB。

上面的set和get都有對應(yīng)的Sync方法,帶Sync的方法為同步方法、不帶Sync的方法為異步方法。

設(shè)置緩存都需要設(shè)置一個key和對應(yīng)的data值,我們在《微信web開發(fā)者工具》中的調(diào)試狀態(tài)下可以點(diǎn)擊調(diào)試窗口的Storage 欄來查看我們緩存在本地的數(shù)據(jù)。

緩存可以保存數(shù)組、數(shù)值、字符串、對象。

設(shè)置緩存

提供setStorage和setStorageSync兩個接口,并且在使用設(shè)置存儲方法時,如果小程序的存儲值當(dāng)中已經(jīng)存在對應(yīng)的key的值,那么會使用新的值替換原來的值。

setSotrage接口

wx.setStorage({
 key:"key",
 data:"value",
 success:function(res){console.log(res)},
 fail:function(res){console.log(res)},
 complete:function(res){console.log(res)},
})
//Object {errMsg: "setStorage:ok"}
//Object {errMsg: "setStorage:ok"}

setStorageSync接口

因?yàn)樵摲椒橥浇涌?,所以直接設(shè)置key和data:

wx.setStorageSync('key', 'value')

上面兩個demo中我們都使用了字符串緩存,當(dāng)然我們也可以緩存一個對象,例如:

wx.setStorage({key:"ob",data:{name:'smallerpig',sex:1,age:18}})

獲取緩存

getSotrage接口

異步接口,所以我們可以定義幾個回調(diào):

wx.getStorage(
{
 key:'key',
 success:function(res){
  console.log(res)//Object {errMsg: "getStorage:ok", data: "value1"}
 },
 fail:function(res){console.log(res)},
 complete:function(res){console.log(res)}
})

其中,我們可以看出來,微信小程序的很多異步接口的回調(diào)都會給出三個回調(diào):success、fail、complete,在執(zhí)行成功的時候回執(zhí)行success、complete回調(diào);在執(zhí)行失敗之后會分別執(zhí)行fail、complete回調(diào)。

getSotrageSync接口

該接口為同步接口,所以只需傳遞對應(yīng)的key值就可以了。如下列代碼:

wx.getStorageSync('ob')
//Object {name: "smallerpig", sex: 1, age: 18}

獲取當(dāng)前存儲總結(jié)

使用wx.getStorageInfo接口

例如下列代碼:

wx.getStorageInfo({
 success: function(res) {
 console.log(res.keys)
 console.log(res.currentSize)
 console.log(res.limitSize)
 }
//["logs", "r3session", "key"]0: "logs"1: "r3session"2: "key"]
//1
//10240
})

也可以使用同步接口wx.getStorageInfoSync。

緩存的使用

在上一篇文章中,小豬介紹了如何解密通過wx.getUserInfo接口獲取到的cryptedData數(shù)據(jù)。其中的session_key小豬是寫在flask的緩存中,緩存的鍵是寫死為:xcx_session_key。在真實(shí)環(huán)境中我們不能夠這樣寫,因?yàn)檫@樣不同的用戶獲取到的session_key是相同的,所以我們需要給不同的用戶附上不同的緩存key。把flask的緩存key返回給微信小程序,小程序中可以固定一個key值,data值保持flask后臺給到的值。

說的比較繞,這里需要讀者好好理解下。

在flask的代碼的使用code獲取session_key中,使用下列代碼:

@app.route('/user/getuserinfo', methods=['GET', 'POST'])
def getuserinfo():
 code = request.data
 url = 'https://api.weixin.qq.com/sns/jscode2session?appid=%s&secret=%s&js_code=%s&grant_type=authorization_code' % (appid, secret, code)
 r = requests.get(url)
 j = json.loads(r.text)
 r3session_key = binascii.hexlify(os.urandom(64))
 cache.set(r3session_key, j['session_key'])
 return r3session_key

接下來,在wx.request的回調(diào)中把flask中返回的r3session_key保存起來:

wx.request({
 url: 'https://***.smallerpig.com/user/getuserinfo',
 data: r.code,
 method: 'POST',
 success: function(res){
 wx.setStorageSync('r3session', res.data)
 }
})

再接下來,在調(diào)用wx.getUserInfo時將返回的數(shù)據(jù)加上從微信小程序本地緩存中取到的r3session丟給flask來處理,flask根據(jù)來的r3session從本地服務(wù)器的flask緩存中取到微信的值解密cryptedData。這才是一個完整的過程。

小程序的getUserInfo代碼:

wx.getUserInfo({
 success: function (res) {
 that.globalData.userInfo = res.userInfo
 typeof cb == "function" && cb(that.globalData.userInfo)
 //將本地存儲中的r3session值也同樣傳遞到我的服務(wù)器,在服務(wù)器中找出微信給到我們的session_key
 var r3session = wx.getStorageSync('r3session')
 res.r3session = r3session
 wx.request({
  url: 'https://***.smallerpig.com/user/getuserunionid',
  data: res,
  success: function(res){
  // success
  console.log(res)
  },
 })
 }
})

對應(yīng)的flask代碼:

@app.route('/user/getuserunionid', methods=['GET', 'POST'])
def getuserid():
 r = json.loads(request.data)
 encryptedData = r['encryptedData']
 iv = r['iv']
 xcx_session_key = r['r3session']
 session_key = cache.get(xcx_session_key) # 從緩存中取出對應(yīng)r3session對應(yīng)的session_key
 pc = WXBizDataCrypt(appid, session_key)
 return pc.decrypt(encryptedData, iv)

以上就是關(guān)于“微信小程序怎么實(shí)現(xiàn)本地?cái)?shù)據(jù)存儲”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對大家有幫助,若想了解更多相關(guān)的知識內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI