详解vue后台系统登录态管理
程序员文章站
2023-11-30 08:16:40
技术应用
js-cookie + vuex + localstorage 做数据持久化
js-cookie
npm i js-cookie --save
vue...
技术应用
js-cookie + vuex + localstorage 做数据持久化
js-cookie
npm i js-cookie --save
vuex
user.js
import { login, logout } from '@/servers/login' import { gettoken, settoken, removetoken } from '@/utils/auth' // 这是上面的js-cookie暴露出来的方法 const user = { state: { userinfo: "", token: gettoken(), roles: [] }, mutations: { set_token: (state, token) => { state.token = token } }, actions: { // 用户名登录 login({ commit }, userinfo) { const username = userinfo.username.trim() return new promise((resolve, reject) => { login({username: username, password: userinfo.password}).then(res => { if (res.status.statuscode === 0) { const data = res.result commit('set_token', data.token) settoken(data.token) localstorage.setitem('userinfo', json.stringify(data)) resolve() } else { resolve(res.status.statusreason) } }) .catch(error => { reject(error) }) }) }, // 登出 logout({ commit }, userid ) { return new promise((resolve, reject) => { logout({id: userid}).then((res) => { if (res.status.statuscode === 0) { commit('set_token', '') removetoken() localstorage.clear() resolve() } else { resolve(res.status.statusreason) } }) .catch(error => { reject(error) }) }) } } } export default user
getter.js
const getters = { userinfo: state => state.user.userinfo } export default getters
store.js
import vue from 'vue' import vuex from 'vuex' import user from './modules/user' import getters from './getters' vue.use(vuex) const store = new vuex.store({ modules: { user }, getters }) export default store
以上就是整个登录态的设定
在项目中的使用,如下
点击登录后
this.$store.dispatch('login', {username: username, password: password}).then((res) => { console.log(res) if(!res) { // 登录成功后的逻辑 } else { // 登录失败后的逻辑 } })
点击退出后
this.$store.dispatch('logout', userid).then((res) => { if (!res) { // 退出成功的逻辑 } else { // 退出失败的逻辑 } })
需要特别注意的一点,vuex在页面刷新之后会消失掉.
以上所述是小编给大家介绍的vue后台系统登录管理详解整合,希望对大家有所帮助