vue中對(duì)token有效期的深入理解
保持登錄是每個(gè)web頁(yè)面必須要做的,不能一直不停的讓用戶進(jìn)行登錄,也不能讓用戶不登錄就直接進(jìn)入頁(yè)面。token在保持登錄中起到了非常重要的作用,我之前寫過(guò)一篇博客,vue存儲(chǔ)和使用后端傳遞過(guò)來(lái)的token,這篇博客詳細(xì)的說(shuō)明了后端如何向前端傳遞token,前端如何將token保存在localstorage中,并通過(guò)請(qǐng)求攔截的方式判斷token是否過(guò)期。我不確定這么寫是否真的能起到作用,因?yàn)槲液竺鎸懘a的時(shí)候,我發(fā)現(xiàn)我后端明明設(shè)定的token的有效期是10個(gè)小時(shí),而本地localstorage中還一直有這個(gè)token并沒(méi)有清除。于是想了個(gè)辦法,在路由守衛(wèi)這個(gè)環(huán)節(jié)設(shè)置token的有效期,并進(jìn)行驗(yàn)證。記錄一下。
前端新設(shè)置一個(gè)token的有效期
代碼寫在路由處理文件中(router/index.js)
// 路由守衛(wèi)
import jwt_decode from 'jwt-decode'
router.beforeEach((to, from, next) => {
? const EXPIRESTIME = 86400 ?
? const isLogin = localStorage.mytoken ? true : false;
? if (isLogin){
? ? const decode = jwt_decode(localStorage.mytoken)
? ? const date = parseInt(new Date().getTime() / 1000)
? ? if ((date - decode.iat) > EXPIRESTIME){
? ? ? localStorage.removeItem('mytoken')
? ? ? next("/login");
? ? }
? }
? if (to.path == "/login" || to.path == "/register") {
? ? next();
? } else {
? ? isLogin ? next() : next("/login");
? }
});上面的代碼可以看出,我設(shè)定了一個(gè)有效期EXPIRESTIME = 86400,也就是246060一天的時(shí)間
如果本地存儲(chǔ)了token的話,我就對(duì)這個(gè)token進(jìn)行解碼,獲得這個(gè)token的創(chuàng)建時(shí)間iat,并與當(dāng)前時(shí)間new Date().getTime()進(jìn)行比較,注意這里有個(gè)坑,當(dāng)前時(shí)間是int型數(shù)據(jù),單位是毫秒,而iat雖然也是int型數(shù)據(jù),但單位是秒,所以我把當(dāng)前時(shí)間除以1000再比較
如果超過(guò)了這個(gè)有效期,就清除這個(gè)token,然后重定向至登錄頁(yè)面
后面的路由守衛(wèi)比較簡(jiǎn)單,就是正常的放行規(guī)則了
仍然使用后端token的有效期
我想來(lái)想去,還是覺(jué)得上面的思路有點(diǎn)不正常
既然后端已經(jīng)設(shè)置了有效期,為啥前端還要這么操作呢,可能自己對(duì)全棧的理解還是不到位,我又重新看了一下自己大半個(gè)月前寫的那篇博客,我覺(jué)得這個(gè)做法應(yīng)該是科學(xué)可行的,還是把代碼上上來(lái)
import axios from "axios";
import { Message, Loading } from 'element-ui';
import router from "./router"
let loading;
function startLoading(){
? ? loading = Loading.service({
? ? ? ? lock: true,
? ? ? ? text: '數(shù)據(jù)加載中',
? ? ? ? background: 'rgba(0,0,0,0.7)'
? ? })
}
function endLoading(){
? ? loading.close();
}
// 請(qǐng)求攔截
axios.interceptors.request.use(config => {
? ? startLoading();
? ? if(localStorage.eleToken){
? ? ? ? // 設(shè)置統(tǒng)一的請(qǐng)求頭
? ? ? ? config.headers.Authorization = localStorage.eleToken
? ? }
? ? return config
}, error => {
? ? return Promise.reject(error)
})
//響應(yīng)攔截
axios.interceptors.response.use(response => {
? ? endLoading();
? ? return response
}, error => {
? ? // 錯(cuò)誤提醒
? ? endLoading();
? ? Message.error(error.response.data)
? ? // 獲取錯(cuò)誤狀態(tài)碼
? ? const {status} = error.response
? ? if(status == 401){
? ? ? ? Message.error("token失效,請(qǐng)重新登錄")
? ? ? ? localStorage.removeItem('eleToken')
? ? ? ? router.push('/login')
? ? }
? ? return Promise.reject(error)
})
export default axios這個(gè)代碼相當(dāng)于是對(duì)axios進(jìn)行了二次封裝,有很重要的兩點(diǎn):
- 請(qǐng)求攔截時(shí),把token寫進(jìn)請(qǐng)求頭中
- 頁(yè)面響應(yīng)時(shí),判斷token是否失效,失效的狀態(tài)碼為401,一旦監(jiān)測(cè)到出現(xiàn)了401的錯(cuò)誤碼,就說(shuō)明token過(guò)期了,刪除、重定向
我懶得去驗(yàn)證這是不是正確的了,但是我覺(jué)得應(yīng)該沒(méi)啥問(wèn)題
到此這篇關(guān)于vue中對(duì)token有效期的深入理解的文章就介紹到這了,更多相關(guān)vue token有效期內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Vue?Token過(guò)期問(wèn)題的2種解決方案小結(jié)
- Vue中如何處理token過(guò)期問(wèn)題
- Vuex處理用戶Token過(guò)期及優(yōu)化設(shè)置封裝本地存儲(chǔ)操作模塊
- vue實(shí)現(xiàn)token過(guò)期自動(dòng)跳轉(zhuǎn)到登錄頁(yè)面
- 關(guān)于Vue 消除Token過(guò)期時(shí)刷新頁(yè)面的重復(fù)提示問(wèn)題
- Vue 攔截器對(duì)token過(guò)期處理方法
- Vue利用路由鉤子token過(guò)期后跳轉(zhuǎn)到登錄頁(yè)的實(shí)例
相關(guān)文章
前端vue打包項(xiàng)目,如何解決跨域問(wèn)題
這篇文章主要介紹了前端vue打包項(xiàng)目,如何解決跨域問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-05-05
ant design vue中日期選擇框混合時(shí)間選擇器的用法說(shuō)明
這篇文章主要介紹了ant design vue中日期選擇框混合時(shí)間選擇器的用法說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-10-10
vuejs實(shí)現(xiàn)本地?cái)?shù)據(jù)的篩選分頁(yè)功能思路詳解
今天做項(xiàng)目需要一份根據(jù)本地?cái)?shù)據(jù)的篩選分頁(yè)功能,下面小編把vuejs實(shí)現(xiàn)本地?cái)?shù)據(jù)的篩選分頁(yè)功能的實(shí)現(xiàn)思路分享到腳本之家平臺(tái),需要的朋友可以參考下2017-11-11

