亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue保持用戶登錄狀態(tài)(各種token存儲方式)

 更新時間:2021年09月18日 15:24:34   作者:ProgramNotes  
本文主要介紹了Vue保持用戶登錄狀態(tài)(各種token存儲方式),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

在前端中,實現(xiàn)保持用戶登錄狀態(tài)的方法有很多種,你通過可以存Cookie、Session、Token等信息來保持,不管后臺向前端發(fā)送哪個我們要做的就是將這些信息存在在本地瀏覽器中,瀏覽器再次發(fā)送請求時,將設(shè)置了‘鍵'=‘值'的Cookie再次拋給服務(wù)器,服務(wù)器通過Cookie的字段判斷用戶已經(jīng)登錄,則根據(jù)需求處理用戶請求,否則返回400提示用戶先登錄,前面我也分享了相關(guān)的文章:Django:Cookie設(shè)置及跨域問題處理,Django:Cookie搭配Session使用,Django:基于Token的驗證使用 。而作為前端,存儲這些值同樣有多種方式,你可以存在Cookie、LocalStorage、SessionStorage或者Vuex狀態(tài)管理器中,當(dāng)然他們的作用也不同,如Vue:LocalStorage與SessionStorage的區(qū)別與用法。

vue實戰(zhàn)開發(fā)020:LocalStorage與SessionStorage的區(qū)別與用法

怎么設(shè)置Cookie

Django可以通過HttpResponse來響應(yīng)對象的set_cookie,設(shè)置好對應(yīng)的視圖和路由,只要通過瀏覽器訪問該路由,瀏覽器就會自動獲取到set_cookie值并存入到本地(當(dāng)瀏覽器正在運行時通常都存在內(nèi)存中,當(dāng)瀏覽器關(guān)閉時通常會存入硬盤中)。

Django實戰(zhàn)006:Cookie設(shè)置及跨域問題處理

Cookie的缺點:

1,cookie存儲量小;2,cookie存儲個數(shù)有限;3,增加網(wǎng)絡(luò)負(fù)擔(dān);4,存在安全隱患

 LocalStorage與SessionStorage存儲Token

如存入SessionStorage,在用戶登錄的時候,我們就需要將用戶名id和token存入sessionStorge,在Vue中實現(xiàn)同樣簡單的,通過sessionStorage.setItem或者sessionStorage['token']兩種寫法都可以實現(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:'用戶名或者密碼錯誤',
                            type:'warning'
                        })
                        }
                })

這樣我們就可以在瀏覽器的開發(fā)者工具中的application中找到Session Storge查看,里面存的就是我們剛剛獲取的值,至于到底存LocalStorage與SessionStorage,就看項目需求了。

 LocalStorage與SessionStorage的主要區(qū)別:

LocalStorage除非主動刪除,否則會永久存儲在瀏覽器中。

SessionStorage只在當(dāng)前所在窗口關(guān)閉前有效,窗口關(guān)閉后其存儲數(shù)據(jù)也就會被自動清除。

vue實戰(zhàn)開發(fā)020:LocalStorage與SessionStorage的區(qū)別與用法

Vuex存儲Token

 在store文件的state中初始化token,因為state中的數(shù)據(jù)不支持直接修改,所以我們需要定義方法setToken(設(shè)置token) 和 getToken(獲取token),然后我們就可以在登錄接口處引入this.$store.commit('setToken',JSON.stringify(res.data.token)),將后臺傳來的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: {
    //存儲token方法
    //設(shè)置token等于外部傳遞進來的值
    setToken(state, token) {
        state.token = token
        localStorage.token = token //同步存儲token至localStorage
      },
  },
 getters : {
  //獲取token方法
  //判斷是否有token,如果沒有重新賦值,返回給state的token
  getToken(state) {
    if (!state.token) {
      state.token = localStorage.getItem('token')
    }
    return state.token
    }
  },
  actions: {
 
  }
})

為什么要使用Vuex

Vuex是一個狀態(tài)管理器而非一個存儲工具,為什么會把token存入Vuex中呢,在Vuex中封裝的localStorage操作,可以直接使用localStorage操作數(shù)據(jù),但無法監(jiān)聽數(shù)據(jù)改變。而Vuex是全局存儲同時可監(jiān)聽數(shù)據(jù)狀態(tài)的變更,當(dāng)Vuex數(shù)值發(fā)生變化時可以響應(yīng)式地監(jiān)聽到該數(shù)據(jù)的變化。

到此這篇關(guān)于Vue保持用戶登錄狀態(tài)(各種token存儲方式)的文章就介紹到這了,更多相關(guān)Vue保持用戶登錄內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue自定義組件實現(xiàn)v-model雙向數(shù)據(jù)綁定的方法

    Vue自定義組件實現(xiàn)v-model雙向數(shù)據(jù)綁定的方法

    這篇文章主要介紹了Vue自定義組件實現(xiàn)v-model雙向數(shù)據(jù)綁定的方法,文中通過代碼示例講解的非常詳細(xì),對大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2024-11-11
  • Vue.js項目前端多語言方案的思路與實踐

    Vue.js項目前端多語言方案的思路與實踐

    前端的國際化是一個比較常見的需求,但網(wǎng)上關(guān)于這一方面的直接可用的方案卻不多,這篇文章主要給大家介紹了關(guān)于Vue.js項目前端多語言方案的思路與實踐,需要的朋友可以參考下
    2021-07-07
  • vue實現(xiàn)后臺管理權(quán)限系統(tǒng)及頂欄三級菜單顯示功能

    vue實現(xiàn)后臺管理權(quán)限系統(tǒng)及頂欄三級菜單顯示功能

    這篇文章主要介紹了vue實現(xiàn)后臺管理權(quán)限系統(tǒng)及頂欄三級菜單顯示功能,本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-06-06
  • 詳解Vue如何通過URL傳遞與獲取參數(shù)

    詳解Vue如何通過URL傳遞與獲取參數(shù)

    Vue Router 路由實際上就是一種映射關(guān)系,例如,多個選項卡之間的切換就可以使用路由功能來實現(xiàn),在實際的開發(fā)中,經(jīng)常需要通過URL來傳遞參數(shù),同時在 JavaScript 腳本中需要獲取URL中的參數(shù),下面將介紹 Vue 項目中,如何通過 URL 對參數(shù)進行傳遞與獲取,需要的朋友可以參考下
    2024-09-09
  • vue實現(xiàn)的微信機器人聊天功能案例【附源碼下載】

    vue實現(xiàn)的微信機器人聊天功能案例【附源碼下載】

    這篇文章主要介紹了vue實現(xiàn)的微信機器人聊天功能,結(jié)合實例形式分析了基于vue.js的微信機器人聊天相關(guān)界面布局、ajax交互等操作技巧,并附帶源碼供讀者下載參考,需要的朋友可以參考下
    2019-02-02
  • Vue實現(xiàn)二維碼的展示及下載功能

    Vue實現(xiàn)二維碼的展示及下載功能

    這篇文章主要介紹了Vue實現(xiàn)二維碼的展示及下載功能,其中downloadQRCode()函數(shù)中的url為要下載的文件的路徑,本文通過實例代碼給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧
    2024-05-05
  • Vue項目中定義全局變量的幾種常用方法總結(jié)

    Vue項目中定義全局變量的幾種常用方法總結(jié)

    在項目中經(jīng)常有些函數(shù)和變量是需要復(fù)用,比如說網(wǎng)站服務(wù)器地址,從后臺拿到的用戶的登錄token,用戶的地址信息等,這時候就需要設(shè)置一波全局變量,這篇文章主要給大家介紹了關(guān)于Vue項目中定義全局變量的幾種常用方法的相關(guān)資料,需要的朋友可以參考下
    2023-12-12
  • Vue?+?Element?自定義上傳封面組件功能

    Vue?+?Element?自定義上傳封面組件功能

    這篇文章主要介紹了Vue?+?Element?自定義上傳封面組件,本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-01-01
  • 解決使用Vue.js顯示數(shù)據(jù)的時,頁面閃現(xiàn)原始代碼的問題

    解決使用Vue.js顯示數(shù)據(jù)的時,頁面閃現(xiàn)原始代碼的問題

    下面小編就為大家分享一篇解決使用Vue.js顯示數(shù)據(jù)的時,頁面閃現(xiàn)原始代碼的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02
  • VUE配置proxy代理的開發(fā)測試及生產(chǎn)環(huán)境

    VUE配置proxy代理的開發(fā)測試及生產(chǎn)環(huán)境

    這篇文章主要為大家介紹了VUE配置proxy代理的開發(fā)環(huán)境、測試環(huán)境、生產(chǎn)環(huán)境詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-08-08

最新評論