vue登錄成功之后的token處理詳細(xì)步驟
1、什么是Token
Token是用戶登錄成功之后服務(wù)端返回的一個(gè)身份令牌,在項(xiàng)目中經(jīng)常要使用。
例如:訪問需要授權(quán)的API接口、校驗(yàn)頁(yè)面的訪問權(quán)限等。
同時(shí),這里我們還需要將token數(shù)據(jù)進(jìn)行存儲(chǔ),這樣在訪問其它的頁(yè)面組件的時(shí)候,就可以獲取token數(shù)據(jù)來進(jìn)行校驗(yàn)。
2、token數(shù)據(jù)存儲(chǔ)在哪里呢?
第一種情況存儲(chǔ)在本地:
存儲(chǔ)到本地的問題是,數(shù)據(jù)不是響應(yīng)式的。
第二種情況存儲(chǔ)到vuex中:
存儲(chǔ)到vuex中獲取方便,并且是響應(yīng)式的。但是存儲(chǔ)到vuex中也會(huì)有問題,就是當(dāng)我們刷新瀏覽器的時(shí)候,數(shù)據(jù)就會(huì)丟失,所以還是需要把token數(shù)據(jù)存放到本地,存儲(chǔ)到本地的目的就是為了進(jìn)行持久化。
所以這里我們需要在登錄成功以后,把token數(shù)據(jù)存儲(chǔ)到vuex中,這樣可以實(shí)現(xiàn)響應(yīng)式,在本地存儲(chǔ)就是為了解決持久化的問題。
3.配置vuex
第一步安裝最新版本的Vuex:
npm install vuex@next --save
第二步在src目錄下面創(chuàng)建store目錄,在store目錄中index.js文件,該文件中的代碼如下所示:
import { createStore } from "vuex"; const store = createStore({ state: { //存儲(chǔ)當(dāng)前登錄用戶信息,包含token等數(shù)據(jù) user: null, }, mutations: { setUser(state, data) { state.user = data; }, }, }); export default store;
在上面的代碼中,創(chuàng)建了store容器,同時(shí)指定了state對(duì)象,在該對(duì)象中定義user屬性存儲(chǔ)登錄用戶信息。
在mutations中定義setUser方法,完成用戶信息的更新。
下面,要實(shí)現(xiàn)的就是,當(dāng)?shù)卿洺晒σ院?,更新user這個(gè)狀態(tài)屬性。
第三步把store注入到Vue的實(shí)例中:
import { createApp } from "vue"; import App from "./App.vue"; import Vant from "vant"; import "vant/lib/index.css"; import "amfe-flexible"; import "./styles/index.css"; import router from "./router"; import store from "./store"; //導(dǎo)入store createApp(App).use(Vant).use(router).use(store).mount("#app"); //完成store的注冊(cè)操作
在main.js文件中,我們導(dǎo)入了store,并且注冊(cè)到了Vue實(shí)例中。
第四步在登陸頁(yè)面中,把登錄信息存儲(chǔ)到store容器中:
import { reactive, toRefs, ref } from "vue"; import { login, sendSms } from "../../api/user"; import { Toast } from "vant"; import { useStore } from "vuex"; //導(dǎo)入useStore
在代碼中導(dǎo)入useStore。
export default { setup() { const loginForm = ref(); //獲取store const store = useStore();
在setup函數(shù)中,調(diào)用useStore方法,獲取store容器。
return { ...toRefs(user), ...useSubmit(user, store),//在調(diào)用useSubmit方法的時(shí)候傳遞store容器 userFormRules, loginForm, };
//用戶登錄 function useSubmit(user, store) { const onSubmit = async () => { //1、獲取表單數(shù)據(jù) //2、表單驗(yàn)證 //3、提交表單請(qǐng)求 Toast.loading({ message: "登錄中...", forbidClick: true, //禁用背景點(diǎn)擊 duration: 0, //持續(xù)時(shí)間,默認(rèn)是2000毫秒,如果為0則持續(xù)展示 }); const res = await login(user); if (res.data.code === 0) { store.commit("setUser", res.data); Toast.success("用戶登錄成功"); } else { Toast.fail("用戶名或密碼錯(cuò)誤"); } //4、根據(jù)請(qǐng)求響應(yīng)結(jié)果處理后續(xù)操作。 }; return { onSubmit, }; }
登錄成功以后,獲取到返回的數(shù)據(jù),同時(shí)調(diào)用store中的commit方法完成數(shù)據(jù)的保存
我們雖然把登錄成功的數(shù)據(jù),存儲(chǔ)到Vuex中,但是當(dāng)我們刷新瀏覽器的時(shí)候,Vuex中的數(shù)據(jù)還是會(huì)丟失的。所以這里,我們還需要將其存儲(chǔ)到本地中。
第五步將Token其存儲(chǔ)到本地中:
下面修改一下store/index.js文件中的代碼:
import { createStore } from "vuex"; const TOKEN_KEY = "TOUTIAO_USER"; const store = createStore({ state: { //存儲(chǔ)當(dāng)前登錄用戶信息,包含token等數(shù)據(jù) // user: null, user: JSON.parse(window.localStorage.getItem(TOKEN_KEY)), }, mutations: { setUser(state, data) { state.user = data; window.localStorage.setItem(TOKEN_KEY, JSON.stringify(state.user)); }, }, }); export default store;
在mutations中的setUser方法中,將登錄成功的用戶數(shù)據(jù)存儲(chǔ)到了localStorage中,在存儲(chǔ)的時(shí)候,將數(shù)據(jù)轉(zhuǎn)成了字符串。
同時(shí)在state中獲取數(shù)據(jù)的時(shí)候,就從localStorage中獲取,當(dāng)然獲取的時(shí)候,再將其轉(zhuǎn)換成對(duì)象的形式。
4.封裝本地存儲(chǔ)操作
在我們的項(xiàng)目中,有很多的地方都需要獲取本地存儲(chǔ)的數(shù)據(jù),如果每次都寫:
JSON.parse(window.localStorage.getItem(TOKEN_KEY)), window.localStorage.setItem(TOKEN_KEY, JSON.stringify(state.user));
就比較麻煩了。所以這里我們建議把操作本地?cái)?shù)據(jù)單獨(dú)的封裝到一個(gè)模塊中。
在utils目錄下面創(chuàng)建storage.js文件,該文件中的代碼如下所示:
// 存儲(chǔ)數(shù)據(jù) export const setItem = (key, value) => { //將數(shù)組,對(duì)象類型的數(shù)據(jù)轉(zhuǎn)換為JSON格式的字符串進(jìn)行存儲(chǔ) if (typeof value === "object") { value = JSON.stringify(value); } window.localStorage.setItem(key, value); }; //獲取數(shù)據(jù) export const getItem = (key) => { const data = window.localStorage.getItem(key); //這里使用try..catch的,而不是通過if判斷一下是否為json格式的字符串,然后在通過parse進(jìn)行轉(zhuǎn)換呢,目的就是是為了方便處理,因?yàn)閷?duì)字符串進(jìn)行判斷看一下是否為json格式的字符串,比較麻煩一些。還需要通過正則表達(dá)式來完成。而通過try..catch比較方便 // 如果data不是一個(gè)有效的json格式字符串,JSON.parse就會(huì)出錯(cuò)。 try { return JSON.parse(data); } catch (e) { return data; } }; //刪除數(shù)據(jù) export const removeItem = (key) => { window.localStorage.removeItem(key);
下面返回到store/index.js文件中,修改對(duì)應(yīng)的代碼,這里使用我們上面封裝好的代碼。
import { createStore } from "vuex"; import { getItem, setItem } from "../utils/storage"; const TOKEN_KEY = "TOUTIAO_USER"; const store = createStore({ state: { //存儲(chǔ)當(dāng)前登錄用戶信息,包含token等數(shù)據(jù) // user: null, // user: JSON.parse(window.localStorage.getItem(TOKEN_KEY)), user: getItem(TOKEN_KEY), }, mutations: { setUser(state, data) { state.user = data; setItem(TOKEN_KEY, state.user); // window.localStorage.setItem(TOKEN_KEY, JSON.stringify(state.user)); }, }, }); export default store;
在上面的代碼中,我們導(dǎo)入getItem和setItem兩個(gè)方法,然后在存儲(chǔ)登錄用戶信息,和獲取登錄用戶信息的時(shí)候,直接使用這兩個(gè)方法,這樣就非常簡(jiǎn)單了。
下面返回瀏覽器進(jìn)行測(cè)試。
把以前l(fā)ocalStorage中存儲(chǔ)的內(nèi)容刪除掉。
然后重新輸入用戶名和密碼,發(fā)現(xiàn)對(duì)應(yīng)的localStorage中存儲(chǔ)了對(duì)應(yīng)的數(shù)據(jù)。
總結(jié)
到此這篇關(guān)于vue登錄成功之后的token處理詳細(xì)步驟的文章就介紹到這了,更多相關(guān)vue登錄成功token處理內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue使用Element組件時(shí)v-for循環(huán)里的表單項(xiàng)驗(yàn)證方法
這篇文章主要介紹了vue使用Element組件時(shí)v-for循環(huán)里的表單項(xiàng)驗(yàn)證方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-06-06Vue+Vite項(xiàng)目初建(axios+Unocss+iconify)的實(shí)現(xiàn)
一個(gè)好的項(xiàng)目開始搭建總是需要配置許多初始化配置,本文就來介紹一下Vue+Vite項(xiàng)目初建(axios+Unocss+iconify)的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2024-02-02Vue項(xiàng)目中實(shí)現(xiàn)帶參跳轉(zhuǎn)功能
最近做了一個(gè)手機(jī)端系統(tǒng),其中遇到了父頁(yè)面需要攜帶參數(shù)跳轉(zhuǎn)至子頁(yè)面的問題,現(xiàn)已解決,下面分享一下實(shí)現(xiàn)過程,感興趣的朋友一起看看吧2021-04-04vue?LogicFlow更多配置選項(xiàng)示例詳解
這篇文章主要為大家介紹了vue?LogicFlow更多配置選項(xiàng)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01element table跨分頁(yè)多選及回顯的實(shí)現(xiàn)示例
本文主要介紹了element table跨分頁(yè)多選及回顯的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02一個(gè)基于vue3+ts+vite項(xiàng)目搭建初探
當(dāng)市面上主流的組件庫(kù)不能滿足我們業(yè)務(wù)需求的時(shí)候,那么我們就有必要開發(fā)一套屬于自己團(tuán)隊(duì)的組件庫(kù),下面這篇文章主要給大家介紹了一個(gè)基于vue3+ts+vite項(xiàng)目搭建的相關(guān)資料,需要的朋友可以參考下2022-05-05利用VUE框架,實(shí)現(xiàn)列表分頁(yè)功能示例代碼
本篇文章主要介紹了利用VUE框架,實(shí)現(xiàn)列表分頁(yè)功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-01-01