基于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 相关文章推荐
简洁短小的 JavaScript IE 浏览器判定代码
Mar 21 Javascript
页面右下角弹出提示框示例代码js版
Aug 02 Javascript
js 针对html DOM元素操作等经验累积
Mar 11 Javascript
基于jquery实现的可编辑下拉框实现代码
Aug 02 Javascript
jquery判断浏览器后退时候弹出消息的方法
Aug 11 Javascript
jQuery给动态添加的元素绑定事件的方法
Mar 09 Javascript
vue单页面打包文件大?首次加载慢?nginx带你飞,从7.5M到1.3M蜕变过程(推荐)
Jan 16 Javascript
jQuery实现的图片点击放大缩小功能案例
Jan 02 jQuery
Vue实现手机扫描二维码预览页面效果
May 28 Javascript
Vue 组件复用多次自定义参数操作
Jul 27 Javascript
基于Vue3.0开发轻量级手机端弹框组件V3Popup的场景分析
Dec 30 Vue.js
js 数组 fill() 填充方法
Nov 02 Javascript
详解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/05/10 PHP
PHP MYSQL实现登陆和模糊查询两大功能
2016/02/05 PHP
PHP使用curl模拟post上传及接收文件的方法
2016/03/04 PHP
PHP magento后台无法登录问题解决方法
2016/11/24 PHP
使用vs code编辑调试php配置的方法
2019/01/29 PHP
11款基于Javascript的文件管理器
2009/10/25 Javascript
javascript多种数据类型表格排序代码分析
2010/09/11 Javascript
非常强大的 jQuery.AsyncBox 弹出对话框插件
2011/08/29 Javascript
JQuery验证工具类搜集整理
2013/01/16 Javascript
js渐变显示渐变消失示例代码
2013/08/01 Javascript
jQuery - css() 方法示例详解
2014/01/16 Javascript
Js保留小数点的4种效果实现代码分享
2014/04/12 Javascript
Backbone.js的一些使用技巧
2015/07/01 Javascript
AngularJS入门教程中SQL实例详解
2016/07/27 Javascript
[原创]JavaScript语法高亮插件highlight.js用法详解【附highlight.js本站下载】
2016/11/01 Javascript
最新Javascript程序员面试试题和解题方法
2017/11/23 Javascript
微信小程序iOS下拉白屏晃动问题解决方案
2019/10/12 Javascript
Vue中强制组件重新渲染的正确方法
2021/01/03 Vue.js
[01:02:25]2014 DOTA2华西杯精英邀请赛 5 24 iG VS DK
2014/05/26 DOTA
使用python和Django完成博客数据库的迁移方法
2018/01/05 Python
Django在admin后台集成TinyMCE富文本编辑器的例子
2019/08/09 Python
django有外键关系的两张表如何相互查找
2020/02/10 Python
如何使用Python发送HTML格式的邮件
2020/02/11 Python
利用matplotlib为图片上添加触发事件进行交互
2020/04/23 Python
Python爬虫如何应对Cloudflare邮箱加密
2020/06/24 Python
CSS3实现可爱的小黄人动画
2016/07/11 HTML / CSS
大韩航空官方网站:Korean Air
2017/10/25 全球购物
结构和类有什么异同
2012/07/16 面试题
《美丽的小兴安岭》教学反思
2014/02/26 职场文书
工伤事故处理协议书怎么写
2014/10/15 职场文书
预备党员入党感言
2015/08/01 职场文书
《学会看病》教学反思
2016/02/17 职场文书
pycharm2021激活码使用教程(永久激活亲测可用)
2021/03/30 Python
教你如何使用Python下载B站视频的详细教程
2021/04/29 Python
将Python代码打包成.exe可执行文件的完整步骤
2021/05/12 Python
Ubuntu Server 安装Tomcat并配置systemctl
2022/04/28 Servers