Vue保持用戶登錄狀態(tài)(各種token存儲(chǔ)方式)
在前端中,實(shí)現(xiàn)保持用戶登錄狀態(tài)的方法有很多種,你通過可以存Cookie、Session、Token等信息來保持,不管后臺(tái)向前端發(fā)送哪個(gè)我們要做的就是將這些信息存在在本地瀏覽器中,瀏覽器再次發(fā)送請(qǐng)求時(shí),將設(shè)置了‘鍵'=‘值'的Cookie再次拋給服務(wù)器,服務(wù)器通過Cookie的
字段判斷用戶已經(jīng)登錄,則根據(jù)需求處理用戶請(qǐng)求,否則返回400提示用戶先登錄,前面我也分享了相關(guān)的文章:Django:Cookie設(shè)置及跨域問題處理,Django:Cookie搭配Session使用,Django:基于Token的驗(yàn)證使用 。而作為前端,存儲(chǔ)這些值同樣有多種方式,你可以存在Cookie、LocalStorage、SessionStorage或者Vuex狀態(tài)管理器中,當(dāng)然他們的作用也不同,如Vue:LocalStorage與SessionStorage的區(qū)別與用法。
怎么設(shè)置Cookie
Django可以通過HttpResponse來
響應(yīng)對(duì)象的set_cookie,設(shè)置好對(duì)應(yīng)的視圖和路由,只要通過瀏覽器訪問該路由,瀏覽器就會(huì)自動(dòng)獲取到set_cookie值并存入到本地(當(dāng)瀏覽器正在運(yùn)行時(shí)通常都存在內(nèi)存中,當(dāng)瀏覽器關(guān)閉時(shí)通常會(huì)存入硬盤中)。
Cookie的缺點(diǎn):
1,cookie存儲(chǔ)量?。?,cookie存儲(chǔ)個(gè)數(shù)有限;3,增加網(wǎng)絡(luò)負(fù)擔(dān);4,存在安全隱患
LocalStorage與SessionStorage存儲(chǔ)Token
如存入SessionStorage,在用戶登錄的時(shí)候,我們就需要將用戶名id和token存入sessionStorge,在Vue中實(shí)現(xiàn)同樣簡單的,通過sessionStorage.setItem或者sessionStorage['token']兩種寫法都可以實(shí)現(xiàn)。
.then(res =>{ if(res.data['code']==200){ localStorage.clear() localStorage.setItem('info',1) localStorage['flag']=1 // localStorage.setItem('flag',1) sessionStorage.clear() // sessionStorage['userid']=JSON.stringify(res.data.userInfo.id) sessionStorage.setItem('userid',JSON.stringify(res.data.userInfo.id)) sessionStorage['token']=JSON.stringify(res.data.token) this.$message({ message:'登錄成功', type:'success' }) this.$router.push('/home') }else{ this.$message({ message:'用戶名或者密碼錯(cuò)誤', type:'warning' }) } })
這樣我們就可以在瀏覽器的開發(fā)者工具中的application中找到Session Storge查看,里面存的就是我們剛剛獲取的值,至于到底存LocalStorage與SessionStorage,就看項(xiàng)目需求了。
LocalStorage與SessionStorage的主要區(qū)別:
LocalStorage除非主動(dòng)刪除,否則會(huì)永久存儲(chǔ)在瀏覽器中。
SessionStorage只在當(dāng)前所在窗口關(guān)閉前有效,窗口關(guān)閉后其存儲(chǔ)數(shù)據(jù)也就會(huì)被自動(dòng)清除。
Vuex存儲(chǔ)Token
在store文件的state中初始化token,因?yàn)閟tate中的數(shù)據(jù)不支持直接修改,所以我們需要定義方法setToken(設(shè)置token) 和 getToken(獲取token),然后我們就可以在登錄接口處引入this.$store.commit('setToken',JSON.stringify(res.data.token)),將后臺(tái)傳來的token存入Vuex和localStorage中,為什么還要存入localStorage,Vuex中的狀態(tài)一旦頁面刷新就不再存在,為了保持當(dāng)前狀態(tài),需要通過localStorage中提取狀態(tài)再傳值給Vuex。
import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) export default new Vuex.Store({ state: { token:'' //初始化token }, mutations: { //存儲(chǔ)token方法 //設(shè)置token等于外部傳遞進(jìn)來的值 setToken(state, token) { state.token = token localStorage.token = token //同步存儲(chǔ)token至localStorage }, }, getters : { //獲取token方法 //判斷是否有token,如果沒有重新賦值,返回給state的token getToken(state) { if (!state.token) { state.token = localStorage.getItem('token') } return state.token } }, actions: { } })
為什么要使用Vuex
Vuex是一個(gè)狀態(tài)管理器而非一個(gè)存儲(chǔ)工具,為什么會(huì)把token存入Vuex中呢,在Vuex中封裝的localStorage操作,可以直接使用localStorage操作數(shù)據(jù),但無法監(jiān)聽數(shù)據(jù)改變。而Vuex是全局存儲(chǔ)同時(shí)可監(jiān)聽數(shù)據(jù)狀態(tài)的變更,當(dāng)Vuex數(shù)值發(fā)生變化時(shí)可以響應(yīng)式地監(jiān)聽到該數(shù)據(jù)的變化。
到此這篇關(guān)于Vue保持用戶登錄狀態(tài)(各種token存儲(chǔ)方式)的文章就介紹到這了,更多相關(guān)Vue保持用戶登錄內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue自定義組件實(shí)現(xiàn)v-model雙向數(shù)據(jù)綁定的方法
這篇文章主要介紹了Vue自定義組件實(shí)現(xiàn)v-model雙向數(shù)據(jù)綁定的方法,文中通過代碼示例講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-11-11Vue.js項(xiàng)目前端多語言方案的思路與實(shí)踐
前端的國際化是一個(gè)比較常見的需求,但網(wǎng)上關(guān)于這一方面的直接可用的方案卻不多,這篇文章主要給大家介紹了關(guān)于Vue.js項(xiàng)目前端多語言方案的思路與實(shí)踐,需要的朋友可以參考下2021-07-07vue實(shí)現(xiàn)后臺(tái)管理權(quán)限系統(tǒng)及頂欄三級(jí)菜單顯示功能
這篇文章主要介紹了vue實(shí)現(xiàn)后臺(tái)管理權(quán)限系統(tǒng)及頂欄三級(jí)菜單顯示功能,本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-06-06vue實(shí)現(xiàn)的微信機(jī)器人聊天功能案例【附源碼下載】
這篇文章主要介紹了vue實(shí)現(xiàn)的微信機(jī)器人聊天功能,結(jié)合實(shí)例形式分析了基于vue.js的微信機(jī)器人聊天相關(guān)界面布局、ajax交互等操作技巧,并附帶源碼供讀者下載參考,需要的朋友可以參考下2019-02-02Vue項(xiàng)目中定義全局變量的幾種常用方法總結(jié)
在項(xiàng)目中經(jīng)常有些函數(shù)和變量是需要復(fù)用,比如說網(wǎng)站服務(wù)器地址,從后臺(tái)拿到的用戶的登錄token,用戶的地址信息等,這時(shí)候就需要設(shè)置一波全局變量,這篇文章主要給大家介紹了關(guān)于Vue項(xiàng)目中定義全局變量的幾種常用方法的相關(guān)資料,需要的朋友可以參考下2023-12-12解決使用Vue.js顯示數(shù)據(jù)的時(shí),頁面閃現(xiàn)原始代碼的問題
下面小編就為大家分享一篇解決使用Vue.js顯示數(shù)據(jù)的時(shí),頁面閃現(xiàn)原始代碼的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-02-02VUE配置proxy代理的開發(fā)測試及生產(chǎn)環(huán)境
這篇文章主要為大家介紹了VUE配置proxy代理的開發(fā)環(huán)境、測試環(huán)境、生產(chǎn)環(huán)境詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08