当前位置: 移动技术网 > IT编程>脚本编程>vue.js > 详解vue后台系统登录态管理

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

2019年07月23日  | 移动技术网IT编程  | 我要评论

抗渗仪,吴宗宪中文网,重生悟空修妖录

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

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网