成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

給localStorage加上過期時間

davidac / 3151人閱讀

摘要:定時器時間到了就將中存的信息以及存的時間信息就是那個對象中的刪掉就行了。難道存了三條我就做三個定時器存的條我就做個定時器這也太了而且也并不符合實際。

一、酷酷的開頭

在潛水的時間長達一年之后,我終于鼓起勇氣開始寫我的第一篇文章了。前端小菜,只是想記錄一下自己的想法,望各位看到這文的大佬輕噴。

在現(xiàn)在前后端分離的開發(fā)模式下,存儲信息一般都不在使用以往使用的cookie了,就拿筆主我之前做過的項目來說。我們都是登錄成功了之后后端會返回給我一個token,一般情況下我會將這個token存到localStorage中,后續(xù)再每一次請求中都會將這個token攜帶在請求頭中。 至于為什么要存到localStorage中呢,相信做過單頁web應用的開發(fā)者們也知道,如果不存著,那用戶刷新了就啥都沒有了。

可以見得前端存儲在項目中是越來越重要了,瀏覽器給我們提供了兩個存儲方案,一個是localStorage,一個是sessionStorage。 存到localStorage中的信息是永久存儲,如果用戶不手動刪除或者代碼中沒有localStorage.removeItem(xxx)這樣的調(diào)用那這個信息將永遠不會消失; 在sessionStorage中存儲的信息則是一次性的,用戶關(guān)掉網(wǎng)頁了下一次在進入這個網(wǎng)頁信息就不會再存儲了。 但是在實際項目的運用中,這兩個方案的表現(xiàn)都不是那么令人滿意。就比如說,我想要實現(xiàn)用戶登錄之后七天之內(nèi)不需要再次登錄這樣的功能,token生成了之后,后端設置了這個token的過期時間為7天,ok,傳到前端, 但是針對瀏覽器目前提供的存儲方案,我卻只能選擇永久存儲和一次性存儲。一次性存儲肯定是不能滿足需求的,永久存儲也違背了我的意愿。

二、之前在項目中的解決方式

之前我在項目中的做法是,在用localStorage存儲了token值的同時, 我還存了一個過期時間(一個毫秒數(shù)),然后在項目初始化的時候我就會去檢查這個時間看看是不是已經(jīng)小于當前時間了,如果是就將token刪掉。 這樣后續(xù)項目在使用到這個token的時候token就已經(jīng)從localStorage中被刪掉了。但是這樣做也有一個問題,如果打開項目的時間剛好是還有10s token就過期的話,token也不會被刪掉了。于是我腦袋里就在構(gòu)想一個可(垃)靠(圾)的解決方案,一不做,二不休,我把它封裝成了一個工具。

先厚臉皮的介紹一下我的項目, sweet-storage, 請無視這土的要死的名字。
github的地址為:https://github.com/Chechengyi/sweet-storage。 順便也正(卑)大(鄙)光(無)明(恥)的求一波star。

三、提出新的想法

咳咳咳! 廢話不多說了,講一下我的實現(xiàn)思路。

在遇到有過期時間的存儲需求時, 用我這個項目舉栗子, storage.save("name", "chechengyi", 10000) 這行代碼的意思是我想在localStorage中存一個鍵為name,值為chechengyi的信息,我希望這條信息只存10s,在將信息存入localStorage中的同時,我會把它的過期時間信息以

  {
      key: time
  }

的形式也存到localStorage中。 key就是鍵, time就是這條信息到期的時間。 這里的時間的話應該存的是new Date().getTime()+我們設置的時間。這樣就得到了一個精確的毫秒數(shù)了。 這個過期時間信息在我的項目中以ISTORAGE_RECORD的字段存儲。 然后后面我們在根據(jù)這里面所提取出來的時間,即:new Date().getTime()-time這個時間去做一個定時器。定時器時間到了就將localStorage中存的信息以及存的時間信息就是那個對象中的key-time刪掉就行了。

但是這里也有一個問題,就是??赡芪覀冃枰羞^期時間存儲的時間不只有一條啊。難道存了三條我就做三個定時器?存的100條我就做100個定時器? 這也太low了而且也并不符合實際。于是我冥思苦想,發(fā)現(xiàn)我前幾天剛學習的優(yōu)先隊列很適合用在這里。

我們可以這樣做,基于ISTORAGE_RECORD拿出來的對象里的time去做一個最小堆(我的這個優(yōu)先隊列是基于最小堆的),最小堆嘛,根節(jié)點肯定就是最小的,time最小的那個不就是最先執(zhí)行的定時器嗎? 等這個定時器執(zhí)行時就刪掉localStorage里存的信息和時間信息,然后優(yōu)先隊列出列,下一個排隊等著出列的元素就是下一個時間最近,等著過期的信息了。這里涉及到了最小堆數(shù)據(jù)結(jié)構(gòu)的操作就不多講了。有興趣的同學可以自己去看看實現(xiàn)。這就是我的項目實現(xiàn)的大概思路, 真正實現(xiàn)的話還要去考慮還沒過期就被用戶刪除了等等的情況。

到這里了我又在想,不行啊,這樣過期了也只是“悄悄”的過期了。 我想知道它什么時候過期的,也就是我希望它過期的時候能通知我一聲行不行?。?于是經(jīng)過我又一輪的冥思苦想,我發(fā)現(xiàn)我去年學的發(fā)布-訂閱模式可以用到這里。然后就是代碼實現(xiàn)啦,無非就是做了一個observers對象。 以存儲的key名去訂閱了一個事件,在我的項目中就是storage.on("name", (key)=>{}) 然后再定時器執(zhí)行的時候我會observers.trriger("name")去發(fā)布這個事件,并且將需要被刪除掉的信息的key傳入訂閱的函數(shù)當中。 這樣就做到了通知的功能。具體發(fā)布-訂閱模式怎么實現(xiàn)的也不在此多做贅述了。

四、無恥的總結(jié)

sweet-storage 實現(xiàn)的大概思路就說完了,有興趣的同學可以去看看源碼實現(xiàn),在此強調(diào) github的地址為:https://github.com/Chechengyi/sweet-storage。 我的代碼寫的很通(垃)俗易(圾)懂。

我還將這個項目傳到了npm上面, npm install sweet-storage就可以安裝到本地。學以致用,這一年多來在各大論壇潛水每次看到別人分享心得心里都癢癢的,這次總算是下定了決心踏出第一步。在這個過程中也學習到了很多,希望自己能夠堅持下去。

如果有不對的地方希望朋友們指出,希望朋友們多給我提建議

最后在強調(diào)一波?。。?/p>

github的地址為:https://github.com/Chechengyi/sweet-storage。

求star 求fuck......

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/103649.html

相關(guān)文章

  • 淺談cookie,session和localStorage,sessionStorage的區(qū)別

    摘要:保持狀態(tài)保存在瀏覽器端,保存在服務器端存儲的大小單個保存的數(shù)據(jù)不能超過大小沒有限制。的目的是克服由所帶來的一些限制,當數(shù)據(jù)需要被嚴格控制在客戶端時,不需要持續(xù)的將數(shù)據(jù)發(fā)回服務器。的生命周期是僅在當前會話下有效。 寫在前面 既然是淺談,就不會詳細從底層原理解釋這幾個的區(qū)別,就簡單地聊一下,這幾個的區(qū)別,優(yōu)缺點,應用場景 cookie和session 瀏覽器的緩存機制提供了可以將用戶數(shù)據(jù)存...

    frolc 評論0 收藏0
  • 瀏覽器緩存總結(jié)

    摘要:一緩存瀏覽器緩存分為強緩存和協(xié)商緩存。然后瀏覽器收到響應后,會把這個以及響應的資源一起緩存下來。語法保存數(shù)據(jù)到從獲取數(shù)據(jù)從刪除保存的數(shù)據(jù)從刪除所有保存的數(shù)據(jù)參考鏈接九種瀏覽器端緩存機制知多少瀏覽器緩存知識小結(jié)及應用瀏覽器緩存機制剖析 這篇文章只是對我覺得常用的緩存方法的學習記錄。我是通過參考下面參考資料做的總結(jié),大家可以直接看參考鏈接里的文章,他們的記錄更全面且?guī)D。 一、http緩存...

    Flands 評論0 收藏0
  • Cookie, Session, LocalStorage, SessionStorage, Eta

    摘要:理解進公園背景這個公園有一個總公園總公園里有許多小公園總公園是登錄頁面小公園是域名相同的頁面第一次進總公園第一次請求某個服務器工作人員檢查你的入園是否符合條件后端查看是否是注冊以后的用戶通過條件的話工作人員會給你一張票后端會給你一個響應頭這 Cookie, Session, LocalStorage, SessionStorage Cookie 理解 進公園 背景: 這個公園有一個總公...

    imingyu 評論0 收藏0
  • Vue路由之JWT身份認證

    摘要:路由之身份認證一身份認證簡介是目前最流行的跨域身份驗證解決方案,相較于機制,服務器就不需要保存任何數(shù)據(jù)了,也就是說,服務器變成無狀態(tài)了,從而比較容易實現(xiàn)擴展。 Vue路由之JWT身份認證 一、JWT身份認證簡介 JSON Web Token(JWT)是目前最流行的跨域身份驗證解決方案,相較于session機制,服務器就不需要保存任何 session 數(shù)據(jù)了,也就是說,服務器變成無狀態(tài)...

    he_xd 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<