基于vue实现网站前台的权限管理(前后端分离实践)


Posted in Javascript onJanuary 13, 2018

Javascript做为当下的热门语言,用途很广泛,从前端到后端处处可见其存在,该技术如今在我们项目内部也大量使用来开发诸如CMS系统以及其他其他一些数据分析系统的前端页面,为此个人非常感兴趣并将其作为帽子卡的扩展内容来进行课余学习。
Javascript框架鳞次栉比,但基本原理大致相同,因此选用国内人开发的vue.js进行一个初步的尝试。学习vue.js也一周多的时间了,说起vue的主要用法,无外乎Declarative Rendering、Component System、Client-side Routing、Vue-resource、Axios以及视项目大小而决定是否使用的Vuex,学习vue事小,主要转变思维,面向前后端分离的组件式web开发才是真正想去实践的。

正好我的个人网站CodeSheep最近要开发后台管理,因此正好用vue这一套来实现了一下。说到后台管理,绕不开的问题就是权限的管理。既然想实践前后端分离这种思想,因此后台管理的所有web前端的东西应该独立由前端完成,这其中就包括很重要的由前端来根据权限进行相关东西的控制。我们想要做到的是:不同的权限对应着不同的路由,同时页面侧边栏也应该根据不同的权限,来异步生成对应的菜单,讲白了就是后台管理时不同权限的用户其看到的界面菜单是不一样的,因此有了这里实现登录和权限验证的一套流程。
具体实现

1、点击“登录”按钮触发登录事件

this.$store.dispatch('LoginByEmail', this.loginForm).then(() => {
 this.$router.push({ path: '/' }); //登录成功之后重定向到首页
}).catch(err => {
 this.$message.error(err); //登录失败提示错误
});

其中异步触发的actions LoginByEmail的处理内容如下:

LoginByEmail ({ commit }, userInfo) {
   const email = userInfo.email.trim()
   return new Promise((resolve, reject) => {
    loginByEmail(email, userInfo.password).then(response => {
     const data = response.data
     setToken(response.data.token)
     commit('SET_TOKEN', data.token)
     resolve()
    }).catch(error => {
     reject(error)
    })
   })
  }

很容易看出想做的是将从服务器端拿到的token(唯一标示用户身份)放到浏览器本地Cookie中去

2、全局钩子router.beforeEach中拦截路由

这一步是核心,具体处理流程示意如下:

基于vue实现网站前台的权限管理(前后端分离实践)

路由拦截处理流程

具体代码如下:

router.beforeEach((to, from, next) => {
 if (getToken()) { // 判断是否取到token
  if (to.path === '/login') {
   next({ path: '/' })
  } else {
   if (store.getters.roles.length === 0) { // 判断当前用户是否已获取完user_info信息
    store.dispatch('GetInfo').then(res => { // 获取user_info
     const roles = res.data.role
     store.dispatch('GenerateRoutes', { roles }).then(() => { // 生成可访问的路由表
      router.addRoutes(store.getters.addRouters) // 动态添加可访问路由表
      next({ ...to }) // 放行路由
     })
    }).catch(() => {
     store.dispatch('FedLogOut').then(() => {
      next({ path: '/login' })
     })
    })
   } else {
    next() // 放行该路由
   }
  }
 } else {
  if (whiteList.indexOf(to.path) !== -1) { // 在免登录白名单里的路径,继续让其访问
   next()
  } else { // 其他不在白名单里的路径全部让其重定向到登录页面!
   next('/login')
   alert('not in white list, now go to the login page')
  }
 }
})

流程图中几个重要步骤解释一下:

判断前端是否取到了token令牌:getToken()

操作很简单,主要是从Cookie中获取,看token是不是已经拿到了:

export function getToken () {
 return Cookies.get(TokenKey)
}

vuex异步操作store.dispatch('GetInfo'):获取用户信息

GetInfo ({ commit, state }) {
   return new Promise((resolve, reject) => {
    getInfo(state.token).then(response => {
     const data = response.data
     console.log(data)
     commit('SET_ROLES', data.role)
     commit('SET_NAME', data.name)
     resolve(response)
    }).catch(error => {
     reject(error)
    })
   })
  }

操作也很简单,用一个get的restful api从服务器获取用户的角色和名字

vuex异步操作store.dispatch('GenerateRoutes', { roles }):根据不同的roles来生成不同的前台路由

GenerateRoutes ({ commit }, data) {
   return new Promise(resolve => {
    const { roles } = data
    let accessedRouters
    if (roles.indexOf('admin') >= 0) {
     accessedRouters = asyncRouter
    } else {
     accessedRouters = filterAsyncRouter(asyncRouter, roles)
    }
    commit('SET_ROUTERS', accessedRouters)
    resolve()
   })
  }

从代码中可以看出,我这是只区分了管理员角色admin和其他普通用户(即非Aadmin两种权限)

该系列的实践后续还将尝试更多,将会一一撰帖成文,我也是个初学者,路漫漫而求索之。。。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js/jquery判断浏览器的方法小结
Sep 02 Javascript
Bootstrap 网站实例之单页营销网站
Oct 20 Javascript
jQuery中页面返回顶部的方法总结
Dec 30 Javascript
基于vue2.0+vuex+localStorage开发的本地记事本示例
Feb 28 Javascript
js实现适配不同的屏幕大小
Apr 10 Javascript
Angular2.js实现表单验证详解
Jun 23 Javascript
bootstrap精简教程_动力节点Java学院整理
Jul 14 Javascript
提升页面加载速度的插件InstantClick
Sep 12 Javascript
Angular中使用better-scroll插件的方法
Mar 27 Javascript
vue中各选项及钩子函数执行顺序详解
Aug 25 Javascript
Node.js net模块功能及事件监听用法分析
Jan 05 Javascript
Jquery的autocomplete插件用法及参数讲解
Mar 12 jQuery
详解webpack-dev-server使用http-proxy解决跨域问题
Jan 13 #Javascript
vuejs实现递归树型菜单组件
Jan 13 #Javascript
在vue中通过axios异步使用echarts的方法
Jan 13 #Javascript
详解基于vue-cli配置移动端自适应
Jan 13 #Javascript
javascript用rem来做响应式开发
Jan 13 #Javascript
深入理解ES6之数据解构的用法
Jan 13 #Javascript
详解ES6语法之可迭代协议和迭代器协议
Jan 13 #Javascript
You might like
php实现可以设置中奖概率的抽奖程序代码分享
2014/01/19 PHP
laravel 4安装及入门图文教程
2014/10/29 PHP
PHP+jquery+CSS制作头像登录窗(仿QQ登陆)
2016/10/20 PHP
php实现微信支付之企业付款
2018/05/30 PHP
JavaScript 获取当前时间戳的代码
2010/08/05 Javascript
jquery的extend和fn.extend的使用说明
2011/01/09 Javascript
JavaScript面向对象(极简主义法minimalist approach)
2012/07/17 Javascript
前端必备神器 Snap.svg 弹动效果
2014/11/10 Javascript
javascript实现table表格隔行变色的方法
2015/05/13 Javascript
全面解析Bootstrap排版使用方法(标题)
2015/11/30 Javascript
轻松学习jQuery插件EasyUI EasyUI实现拖动基本操作
2015/11/30 Javascript
jQuery简单实现点击文本框复制内容到剪贴板上的方法
2016/08/01 Javascript
JavaScript常用代码书写规范的超全面总结
2016/09/11 Javascript
javaScript动态添加Li元素的实例
2018/02/24 Javascript
JsChart组件使用详解
2018/03/04 Javascript
vue渲染时闪烁{{}}的问题及解决方法
2018/03/28 Javascript
关于vue的语法规则检测报错问题的解决
2018/05/21 Javascript
Python导出DBF文件到Excel的方法
2015/07/25 Python
Python实现改变与矩形橡胶的线条的颜色代码示例
2018/01/05 Python
python使用turtle库与random库绘制雪花
2018/06/22 Python
对Python 多线程统计所有csv文件的行数方法详解
2019/02/12 Python
windows安装TensorFlow和Keras遇到的问题及其解决方法
2019/07/10 Python
python 爬取疫情数据的源码
2020/02/09 Python
Canvas 像素处理之改变透明度的实现代码
2019/01/08 HTML / CSS
Lyle & Scott苏格兰金鹰官网:英国皇室御用品牌
2018/05/09 全球购物
Interflora澳大利亚:同日鲜花速递
2019/06/25 全球购物
SQL数据库笔试题
2016/03/08 面试题
助人为乐表扬信范文
2014/01/14 职场文书
历史专业大学生职业生涯规划书
2014/03/13 职场文书
协议书格式
2014/04/23 职场文书
群众路线专项整治方案
2014/10/27 职场文书
电力工程合作意向书
2015/05/11 职场文书
走进毛泽东观后感
2015/06/04 职场文书
Java Dubbo框架知识点梳理
2021/06/26 Java/Android
深入解析Apache Hudi内核文件标记机制
2022/03/31 Servers
uniapp开发打包多端应用完整方法指南
2022/12/24 Javascript