vue3+pinia用戶信息持久緩存token的問題解決
對博主來說,這是個(gè)相當(dāng)復(fù)雜的問題。
當(dāng)初在使用vue2+vuex進(jìn)行用戶信息持久登錄時(shí),寫了不下3篇博客,確實(shí)是解決了問題,博客鏈接如下
第一篇博客是記錄前端如何使用token,簡言之,就是先把后端傳過來的token寫入到瀏覽器的localstorage緩存中,前端在處理路由之前,先檢查localstorage中有沒有token,有token就放行,沒有token就跳轉(zhuǎn)到登錄界面
第二篇博客是發(fā)現(xiàn)token過期后的處理方式,最后我的vue2項(xiàng)目都沒有使用這篇博客中的解決方案,而是使用了第三篇博客的解決方案
第三篇博客出現(xiàn)的問題是,**每次刷新頁面,store里面的數(shù)據(jù)沒了,而localstorage中還有數(shù)據(jù),**這樣的話,頁面上有些地方需要store的數(shù)據(jù)就加載不出來了,但token并沒有更新,出現(xiàn)了邏輯錯(cuò)誤。解決方案就是每次在啟動(dòng)頁面的時(shí)候,檢查一下localstorage中有沒有數(shù)據(jù),有數(shù)據(jù)的話,重新設(shè)置一下store,當(dāng)然,在路由守衛(wèi)環(huán)節(jié)也添加了路由的放行規(guī)則
我把第三種方案當(dāng)做終極解決方案,確實(shí)很長一段時(shí)間都沒有再受到困擾
知道我現(xiàn)在開始使用vue3+pinia來寫前端項(xiàng)目,問題又來了
pinia和vuex遇到的問題是一樣的,我嘗試用第三篇博客來解決,按道理應(yīng)該是可以解決的,但實(shí)際上一直沒能解決。折騰很長一段時(shí)間,找到了一種比較折中的解決方案
pinia-plugin-persistedstate持久化存儲(chǔ)數(shù)據(jù)
實(shí)際上就是使用這個(gè)pinia-plugin-persistedstate
插件,它解決的問題是,幫你把store中的數(shù)據(jù)持久化的存儲(chǔ)在localstorage中,并且比較好的一點(diǎn)是,當(dāng)你需要使用store中的數(shù)據(jù)時(shí),它又從localstorage中取出來給你去渲染頁面,其實(shí)就和我上面第3篇博客的內(nèi)容差不多,這樣就不怕刷新頁面了,先來看看怎么寫和怎么中
store文件的寫法
直接看代碼:
import { ref } from "vue"; import { defineStore } from "pinia"; import { loginAPI } from "@/apis/user"; export const useUserStore = defineStore( "user", () => { const userInfo = ref({}); const getUserInfo = async (data) => { const res = await loginAPI(data); // console.log(res); userInfo.value = res; // console.log(userInfo.value) }; // 解決刷新頁面丟失store信息的問題 const clearUserInfo = () => { userInfo.value = {}; localStorage.removeItem('user') }; return { userInfo, getUserInfo, clearUserInfo, }; }, { persist: true, } );
pinia用的組合式api寫法
- userInfo是用戶信息
- getUserInfo是通過調(diào)用登錄接口,修改userInfo
- clearUserInfo是清除用戶信息
在代碼的最后面,加了個(gè)對象persist: true
,之后每次登錄,就會(huì)在localstorage中生成一個(gè)key為user的字符串對象,刷新頁面而這個(gè)對象不會(huì)消失,模板上需要渲染的時(shí)候,又把內(nèi)容添加給store,相對來說比較靠譜。命名規(guī)則就是definstore時(shí)定義的變量名。
在我沒有添加路由守衛(wèi)規(guī)則之前,這么寫的話,會(huì)有個(gè)問題,退出登錄后,還能返回到原來的路由,只是頁面上該有的用戶信息都沒有了,因?yàn)?code>clearUserInfo并沒有刪除localstorage中的user對象,user一直都在,那按照之前的邏輯,當(dāng)然行不通了
退出登錄時(shí)的操作
看看具體怎么解決吧
//這是退出登錄用到的方法 const logout = () => { // userStore.clearUserInfo() localStorage.removeItem('user') router.push('/login') }
其實(shí)就是清除localstorage中的user對象
路由守衛(wèi)
路由守衛(wèi)是最麻煩的地方,邏輯理不清楚,就沒法正常跳轉(zhuǎn)
我的寫法
// 路由守衛(wèi) import jwt_decode from "jwt-decode"; router.beforeEach((to, from, next) => { const isLogin = localStorage.user ? true : false; if (isLogin) { const user = JSON.parse(localStorage.user) const decode = jwt_decode(user.userInfo.token); const date = parseInt(new Date().getTime() / 1000); if (date - decode.iat > decode.exp - decode.iat) { localStorage.removeItem("user"); next("/login"); } } if (to.path == "/login") { next(); } else { isLogin ? next() : next("/login"); } });
還是根據(jù)localstorage中是否有user對象來判斷是否登錄,但是前面說過了,它存在localstorage中的是一個(gè)字符串,大體是下面這個(gè)樣子
可以看出來,里面有你定義的state數(shù)據(jù),所以,需要解析先成json才能正常取值,取值后,就是解析其中的token了,解析完token,就可以判斷有沒有過期來清除token了
總之,過程相當(dāng)繁瑣,希望不要再寫第5篇了。
到此這篇關(guān)于vue3+pinia用戶信息持久緩存token的問題解決的文章就介紹到這了,更多相關(guān)vue3 pinia用戶信息持久緩存token內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue2?Dialog彈窗函數(shù)式調(diào)用實(shí)踐示例
這篇文章主要為大家介紹了Vue2?Dialog彈窗函數(shù)式調(diào)用實(shí)踐示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01在vue3項(xiàng)目中實(shí)現(xiàn)國際化的代碼示例
國際化就是指在一個(gè)項(xiàng)目中,項(xiàng)目中的語言可以進(jìn)行切換(中英文切換),那么在實(shí)際項(xiàng)目中是如何實(shí)現(xiàn)的呢,本文就給大家詳細(xì)的介紹實(shí)現(xiàn)方法,需要的朋友可以參考下2023-07-07Vue3實(shí)現(xiàn)掛載全局方法和用getCurrentInstance代替this
這篇文章主要介紹了Vue3實(shí)現(xiàn)掛載全局方法和用getCurrentInstance代替this,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2025-04-04利用vue重構(gòu)有贊商城的思路以及總結(jié)整理
這篇文章主要介紹了利用vue重構(gòu)有贊商城的思路以及總結(jié)整理,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-02-02vue2如何使用vue-i18n搭建多語言切換環(huán)境
這篇文章主要介紹了vue2-使用vue-i18n搭建多語言切換環(huán)境的相關(guān)知識(shí),在data(){}中獲取的變量存在更新this.$i18n.locale的值時(shí)無法自動(dòng)切換的問題,需要刷新頁面才能切換語言,感興趣的朋友一起看看吧2023-12-12