vue路由权限校验功能的实现代码


Posted in Javascript onJune 07, 2020

引言

做后台系统的时候,难免会有用户权限的判断。admin可以查看全部菜单,user只能查看部分菜单。

一开始接触这个需求的时候,完全是纯前端做的。在配置路由的时候,加一个roles的属性,通过判断用户的roles是否与路由的roles属性相匹配来作为显示隐藏的依据

{
 path: '/router',
 name: 'router',
 meta: {
 title: '标题',
 roles: ['admin','user']
 },
 component: index,
 children: [
 {
 path: 'children',
 name: 'children',
 meta: {
 title: '子标题',
 roles: ['admin','user']
 },
 component: child
 }
 ]
}
// 过滤路由 menuList-菜单 roles-用户角色
const checkMenuList = (menuList, roles) => {
 for (let i = 0; i < menuList.length; i++) {
 if (!compareEqual(roles, menuList[i].meta.roles) || menuList[i].meta.noRenderTree) {
 menuList.splice(i, 1)
 i -= 1
 } else {
 if (menuList[i].children) {
 checkMenuList(menuList[i].children, roles)
 }
 }
 }
 return menuList
}

这样做确实可以实现给不同用户展示不同的菜单。但是如果用户权限发生改变,前端就需要发版。本着万物皆可灵活配置的原则。

需求

首先我们要了解,我们要做什么。

我们希望我们可以通过用户权限配置功能,达到灵活配置路由权限,由服务器端返回需要展示的路由权限,前端做展示。

思路

  • 前端配置好项目全部页面的路由
  • 服务器端返回该用户的权限列表,前端去匹配,最后返回一个路由列表,作为菜单
  • 为了更好的用户体验,当用户输入异常的路由时,我们要重定向到一个404页面,提示用户该页面不存在。
  • 基于第3点,我们在每次跳转的时候,还需要判断这个页面是否存在,该用户是否有权限进行跳转

实现

ok 思路整理完了。现在就开始来实现吧!

首先,routers是需要在前端注册,我们要先配置整个页面的routers。

除了系统的菜单之外,我们还需要配置403错误页面,还有login、首页这些基本路由。由于系统菜单还需要与服务器端返回的路由列表进行匹配,暂时不进行注册

// router.js

 // 基本路由
export const defaultRouter = [
 { path: '/', component: index }, // 首页
 { path: '/login', name: 'login', component: login } // 登录页
 ]
 
 // 项目全部页面
export const appRouter = [
 {
 path: '/router1',
 name: 'router1',
 redirect: '/router1/test1',
 component: router1,
 meta: { title: '路由1'},
 children: [
 { path: 'test1', name: 'test1', component: test1, meta: { title: '测试1' } },
 { path: 'test2', name: 'test2', component: test1, meta: { title: '测试2' } }
 ]
 },
 ]
 // 这个是我们页面初始化时候,注册的routes
const routers = [ 
 ...defaultRouter
]
const RouterConfig = {
 routes: routers
}
const router = new VueRouter(RouterConfig)

全部路由都注册完了,接下来就要匹配用户可访问的路由了,这一步需要和服务器端一起约定规则。

// 服务器端返回的键值对: 路由名:是否有权限
authRouter:{
 'test1': false,
 'test2': true
}

拿到服务器端返回的用户权限之后,就开始过滤路由

// 过滤路由 appRouterCopy-项目全部页面 authRouter-权限列表
const checkMenuList = (appRouterCopy, authRouter) => {
 for (let i = 0; i < appRouterCopy.length; i++) {
 let {name, children} = appRouterCopy[i]
 if (authRouter[name] === false) {
  appRouterCopy.splice(i, 1)
  i--
 } else if (children && children.length) {
  checkMenuList(children, authRouter)
 }
 }
}

得到过滤后的路由之后,使用addRoutes进行注册。注意404路由配置要在最后加上。

let error404Page = { path: '/*', name: 'error-404', meta: 
{ 
title: '404-页面不存在'}, component: error404Page
}
router.addRoutes([...appRouterCopy, error404Page])

到此我们就得到了用户有权限的页面了,可以把得到的列表作为系统菜单渲染上去。接下来就要处理一下跳转异常的状况了。需要用到beforeEach对每次跳转进行拦截判断

router.beforeEach(((to, from, next) => {
 if (isNotLog && to.name !== 'login') {
 // 未登录 跳转到登录页
  next({ name: 'login' })
 } else if (to.name && (to.name === 'login' || to.name.indexOf('error') !== -1)){
 // 跳转异常
 next()
 } else {
 // 校验用户权限
 checkUser(next, to ,router)
 }
})

const checkUser = async (next, to ,router) => {
 if (isNotUser) {
 // 首次登陆系统,没有用户信息的时候 需要获取用户信息做过滤路由的操作
 const authRouter = getAuthRouter() // 获取用户权限
 checkMenuList(appRouterCopy, authRouter)
 const error404Page = { path: '/*', name: 'error-404', meta: { title: '404-页面不存在'}, component: error404Page}
 router.addRoutes([...appRouterCopy, error404Page])
 if (!appRouterCopy.length) {
  // 用户没有有权限的路由 可以跳转到404或者登录页
  next({ ...error404Page, replace: true })
 } else {
  next({ ...to, replace: true })
 }
 } else {
 next()
 }
}

总结

到此这篇关于vue路由权限校验功能的实现代码的文章就介绍到这了,更多相关vue路由权限校验内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
用javascript实现给图片加链接
Aug 15 Javascript
js创建数据共享接口——简化框架之间相互传值
Oct 23 Javascript
JS+CSS实现的经典圆角下拉菜单效果代码
Oct 21 Javascript
JQuery解析XML数据的几个简单实例
May 18 Javascript
Node.js的Mongodb使用实例
Dec 30 Javascript
基于JavaScript实现复选框的全选和取消全选
Feb 09 Javascript
80%应聘者都不及格的JS面试题
Mar 21 Javascript
Vue实现动态响应数据变化
Apr 28 Javascript
Vue拖拽组件列表实现动态页面配置功能
Jun 17 Javascript
微信小程序实现图片选择并预览功能
Jul 25 Javascript
JavaScript console的使用方法实例分析
Apr 28 Javascript
vue3 watch和watchEffect的使用以及有哪些区别
Jan 26 Vue.js
Vue使用自定义指令实现拖拽行为实例分析
Jun 06 #Javascript
JS原型对象操作实例分析
Jun 06 #Javascript
JS中的继承操作实例总结
Jun 06 #Javascript
ES6 async、await的基本使用方法示例
Jun 06 #Javascript
JS 数组和对象的深拷贝操作示例
Jun 06 #Javascript
ES6 Generator基本使用方法示例
Jun 06 #Javascript
jquery.validate自定义验证用法实例分析【成功提示与择要提示】
Jun 06 #jQuery
You might like
PR值查询 | PageRank 查询
2006/12/20 PHP
PHP 危险函数全解析
2009/09/09 PHP
浅析PHP页面局部刷新功能的实现小结
2013/06/21 PHP
php有道翻译api调用方法实例
2014/12/22 PHP
php对文件进行hash运算的方法
2015/04/03 PHP
Yii框架安装简明教程
2020/05/15 PHP
终于解决了IE8不支持数组的indexOf方法
2013/04/03 Javascript
js绑定事件this指向发生改变的问题解决方法
2013/04/23 Javascript
js中通过父级进行查找定位元素
2014/06/15 Javascript
Javascript中获取对象的原型对象的方法小结
2015/02/25 Javascript
JS实现Select的option上下移动的方法
2016/03/01 Javascript
分享Bootstrap简单表格、表单、登录页面
2017/08/04 Javascript
echarts大屏字体自适应的方法步骤
2019/07/12 Javascript
js时间转换毫秒的实例代码
2019/08/21 Javascript
Vue实现简易计算器
2020/02/25 Javascript
JavaScript命令模式原理与用法实例详解
2020/03/10 Javascript
JavaScript事件循环及宏任务微任务原理解析
2020/09/02 Javascript
小程序实现录音功能
2020/09/22 Javascript
[03:31]DOTA2英雄基础教程 大地之灵
2013/12/17 DOTA
Python之reload流程实例代码解析
2018/01/29 Python
python tensorflow学习之识别单张图片的实现的示例
2018/02/09 Python
python 接口返回的json字符串实例
2018/03/27 Python
详解Python下Flask-ApScheduler快速指南
2018/11/04 Python
Python中的几种矩阵乘法(小结)
2019/07/10 Python
关于pymysql模块的使用以及代码详解
2019/09/01 Python
Pytorch GPU显存充足却显示out of memory的解决方式
2020/01/13 Python
使用CSS3的::selection改变选中文本颜色的方法
2015/09/29 HTML / CSS
C# Debug和Testing相关面试题
2015/10/25 面试题
幼儿园教师培训制度
2014/01/16 职场文书
大学总结自我鉴定
2014/01/18 职场文书
学校三节实施方案
2014/06/09 职场文书
物业保安岗位职责
2014/07/02 职场文书
2014年酒店工作总结与计划
2014/11/17 职场文书
工作收入证明模板
2015/06/12 职场文书
Django操作cookie的实现
2021/05/26 Python
Python使用pandas导入csv文件内容的示例代码
2022/12/24 Python