欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

详解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

详解vue后台系统登录态管理

vuex

 详解vue后台系统登录态管理

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后台系统登录管理详解整合,希望对大家有所帮助