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


Posted in Javascript onApril 02, 2019

技术应用
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后台系统登录管理详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
Prototype Hash对象 学习
Jul 19 Javascript
利用js读取动态网站从服务器端返回的数据
Feb 10 Javascript
分享28款免费实用的 JQuery 图片和内容滑块插件
Dec 15 Javascript
值得分享的轻量级Bootstrap Table表格插件
May 30 Javascript
jquery过滤特殊字符',防sql注入的实现方法
Aug 17 Javascript
Node.js + Redis Sorted Set实现任务队列
Sep 19 Javascript
JavaScript html5利用FileReader实现上传功能
Mar 27 Javascript
Node.js 的模块知识汇总
Aug 16 Javascript
Angular.js通过自定义指令directive实现滑块滑动效果
Oct 13 Javascript
在vue项目中引入vue-beauty操作方法
Feb 11 Javascript
angular8和ngrx8结合使用的步骤介绍
Dec 01 Javascript
在antd Form表单中select设置初始值操作
Nov 02 Javascript
微信小程序实现人脸识别登陆的示例代码
Apr 02 #Javascript
Angular7中创建组件/自定义指令/管道的方法实例详解
Apr 02 #Javascript
Node.js中package.json中库的版本号(~和^)
Apr 02 #Javascript
基于Vue插入视频的2种方法小结
Apr 02 #Javascript
vue踩坑记-在项目中安装依赖模块npm install报错
Apr 02 #Javascript
小程序实现自定义导航栏适配完美版
Apr 02 #Javascript
es6 symbol的实现方法示例
Apr 02 #Javascript
You might like
php多种形式发送邮件(mail qmail邮件系统 phpmailer类)
2014/01/22 PHP
对PHP新手的一些建议(PHP学习经验总结)
2014/08/20 PHP
对比PHP对MySQL的缓冲查询和无缓冲查询
2016/07/01 PHP
Laravel中间件实现原理详解
2016/10/09 PHP
关于PHP通用返回值设置方法
2017/03/31 PHP
PHP基于imagick扩展实现合成图片的两种方法【附imagick扩展下载】
2017/11/14 PHP
Javascript操纵Cookie实现购物车程序
2007/02/15 Javascript
js DOM模型操作
2009/12/28 Javascript
js代码实现的加入收藏效果并兼容主流浏览器
2014/06/23 Javascript
浅谈Javascript中深复制
2014/12/01 Javascript
浅谈Javascript中的Function与Object
2015/01/26 Javascript
JavaScript编写Chrome扩展实现与浏览器的交互及时间通知
2016/05/16 Javascript
JavaScript中的工厂函数(推荐)
2017/03/08 Javascript
js实现抽奖效果
2017/03/27 Javascript
bootstrap Table插件使用demo
2017/08/07 Javascript
基于Vue实例生命周期(全面解析)
2017/08/16 Javascript
浅谈在fetch方法中添加header后遇到的预检请求问题
2017/08/31 Javascript
JS实现的雪花飘落特效示例
2019/12/03 Javascript
JS实现滑动插件
2020/01/15 Javascript
介绍Python的Django框架中的QuerySets
2015/04/20 Python
python图书管理系统
2020/04/05 Python
python 实现判断ip连通性的方法总结
2018/04/22 Python
解决Mac下首次安装pycharm无project interpreter的问题
2018/10/29 Python
Cython编译python为so 代码加密示例
2019/12/23 Python
python实现处理mysql结果输出方式
2020/04/09 Python
Sephora丝芙兰马来西亚官方网站:国际化妆品购物
2018/03/15 全球购物
华为c/c++笔试题
2016/01/25 面试题
高校十八大报告感想
2014/01/27 职场文书
五年级科学教学反思
2014/02/05 职场文书
优秀党员获奖感言
2014/02/18 职场文书
竞聘书怎么写,如何写?
2014/03/31 职场文书
党的群众路线剖析材料
2014/10/09 职场文书
全民创业工作总结
2015/08/13 职场文书
教师读书活动心得体会
2016/01/14 职场文书
CSS3 实现的图片悬停的切换按钮
2021/04/13 HTML / CSS
如何使用Python对NetCDF数据做空间相关分析
2021/04/21 Python