位置: 编程技术 - 正文

Vue-Access-Control 前端用户权限控制解决方案

编辑:rootadmin

推荐整理分享Vue-Access-Control 前端用户权限控制解决方案,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

Vue-Access-Control是一套基于Vue/Vue-Router/axios 实现的前端用户权限控制解决方案,通过对路由、视图、请求三个层面的控制,使开发者可以实现任意颗粒度的用户权限控制。

整体思路

会话开始之初,先初始化一个只有登录路由的Vue实例,在根组件created钩子里将路由定向到登录页,用户登录成功后前端拿到用户token,设置axios实例统一为请求headers添加{"Authorization":token}实现用户鉴权,然后获取当前用户的权限数据,主要包括路由权限和资源权限,之后动态添加路由,生成菜单,实现权限指令和全局权限验证方法,并为axios实例添加请求拦截器,至此完成权限控制初始化。动态加载路由后,路由组件将随之加载并渲染,而后展现前端界面。

为解决浏览器刷新路由重置的问题,拿到token后要将其保存到sessionStorage,根组件的created钩子负责检查本地是否已有token,如果有则无需登录直接用该token获取权限并初始化,如果token有效且当前路由有权访问,将加载路由组件并正确展现;若当前路由无权访问将按路由设置跳转;如果token失效,后端应返回4xx状态码,前端统一为axios实例添加错误拦截器,遇到4xx状态码执行退出操作,清除sessionStorage数据并跳转到登录页,让用户重新登录。

最小依赖原则

Vue-Access-Control的定位是单一领域解决方案,除了Vue/Vue-Router/axios之外没有其他依赖,理论上可以无障碍的应用到任何有权限控制需求的Vue项目中,项目基于webpack 模板开发构建,大多数新项目可以直接基于检出代码继续开发。需要说明的是,项目额外引入的Element-UI和CryptoJS仅用于开发演示界面,他们不是必须且与权限控制毫无关系,项目应用中可以自行取舍。

目录结构

数据格式约定

路由权限数据必须是如下格式的对象数组,id和parent_id相同的两个路由具有上下级关系,如果希望使用自定义格式的路由数据,需要修改路由控制的相关实现,详见路由控制数据格式约定

 资源权限数据必须是如下格式的对象数组,每个对象代表一个RESTful请求,支持带参数的url,具体格式说明见请求控制

路由控制

路由控制包括动态注册路由和动态生成菜单两部分。

动态注册路由

最初实例化的路由仅包括登录和两个路径,我们期待完整的路由是这样的:

那么接下来就需要获取首页以及其子路由们,思路是事先在本地存一份整个项目的完整路由数据,然后根据用户权限对完整路由进行筛选。

筛选的实现思路是先将后端返回的路由数据处理成如下哈希结构:

然后遍历本地完整路由,在循环中将路径拼接成上述结构中的key格式,通过hashMenus[route]就可以判断路由是否匹配,具体实现见App.vue文件中的getRoutes()方法。

如果后端返回的路由权限数据与约定不同,就需要自行实现筛选逻辑,只要能得到实际可用的路由数据就可以,最终使用addRoutes()方法将他们动态添加到路由实例中,注意页面的模糊匹配一定要放在最后。

动态菜单

路由数据可以直接用来生成导航菜单,但路由数据是在根组件中得到的,导航菜单存在于index.vue组件中,显然我们需要通过某种方式共享菜单数据,方法有很多,一般来说首先想到的是Vuex,但菜单数据在整个用户会话过程中不会发生改变,这并不是Vuex的最佳使用场景,而且为了尽量减少不必要的依赖,这里用了最简单直接的方法,把菜单数据挂在根组件data.menuData上,在首页里用this.$parent.menuData获取。

另外,导航菜单很可能会有添加栏目图标的需求,这可以通过在路由中添加meta数据实现,例如将图标class或unicode存到路由meta里,模板中就可以访问到meta数据,用来生成图标标签。

在多角色系统中可能遇到的一个问题是,不同角色有一个名字相同但功能不同的路由,比如说系统管理员和企业管理员都有”账号管理”这个路由,但他们的操作权限和目标不同,实际上是两个完全不同的界面,而Vue不允许多个路由同名,因此路由的name必须做区分,但把区分后的name显示在前端菜单上会很不美观,为了让不同角色可以享有同一个菜单名称,我们只要将这两个路由的meta.name都设置成”账号管理”,在模板循环时优先使用meta.name就可以了。

菜单的具体实现可以参考views/index.vue。

视图控制

视图控制的目标是根据当前用户权限决定界面元素显示与否,典型场景是对各种操作按钮的显示控制。实现视图控制的本质是实现一个权限验证方法,输入请求权限,输出是否获准。然后配合v-if或jsx或自定义指令就能灵活实现各种视图控制。

Vue-Access-Control 前端用户权限控制解决方案

全局验证方法

验证方法的的实现本身很简单,无非是根据后端给出的资源权限做判断,重点在于优化方法的输入输出,提升易用性,经过实践总结最终使用的方案是,将权限跟请求同时维护,验证方法接收请求对象数组为参数,返回是否具有权限的布尔值。

请求对象格式:

权限验证方法$_has()的调用格式:

权限验证方法的具体实现见App.vue中Vue.prototype.$_has方法。

将权限验证方法全局混入,就可以在项目中很容易的配合v-if实现元素显示控制,这种方式的优点在于灵活,除了可以校验权限外,还可以在判断表达式中加入运行时状态做更多样性的判断,而且可以充分利用v-if响应数据变化的特点,实现动态视图控制。

具体实现细节参考基于Vue实现后台系统权限控制中的相关章节。

自定义指令

v-if的响应特性是把双刃剑,因为判断表达式在运行过程中会频繁触发,但实际上在一个用户会话周期内其权限并不会发生变化,因此如果只需要校验权限的话,用v-if会产生大量不必要的运算,这种情况只需在视图载入时校验一次即可,可以通过自定义指令实现:

 自定义指令内部仍然是调用全局验证方法,但优点在于只会在元素初始化时执行一次,多数情况下都应该使用自定义指令实现视图控制。

请求控制

请求控制是利用axios拦截器实现的,目的是将越权请求在前端拦截掉,原理是在请求拦截器中判断本次请求是否符合用户权限,以决定是否拦截。

普通请求的判断很容易,遍历后端返回的的资源权限格式,直接判断request.method和request.url是否吻合就可以了,对于带参数的url需要使用通配符,这里需要根据项目需求前后端协商一致,约定好通配符格式后,拦截器中要先将带参数的url处理成约定格式,再判断权限,方案中已经实现了以下两种通配符格式:

解释:两个名词之间夹带一个参数,参数通常表示第一个名词的id 

对于第一种格式需要注意的是,如果你要发起一个url为"/aaa/bbb"的请求,默认会被处理成"/aaa/**"进行权限校验,如果这里的”bbb”并不是参数而是url的一部分,那么你需要将url改成"/aaa/bbb/",在最后加一个”/“表示该url不需要转化格式。

拦截器的具体实现见App.vue中的setInterceptor()方法。

如果你的项目还需要其他的通配符格式,只需要在拦截器中实现对应的检测和转化方法就可以了。

演示及说明

演示说明:

DEMO项目中演示了动态菜单、动态路由、按钮权限、请求拦截。

演示项目后端由rap2生成mock数据,登录请求通常应该是POST方式,但因为rap2的编程模式无法获取到非GET的请求参数,因此只能用GET方式登录,实际项目中不建议仿效;

另外登录后获取权限的接口本来不需要携带额外参数,后端可以根据请求头携带的token信息实现用户鉴权,但因为rap2的编程模式获取不到headers数据,因此只能增加一个”Authorization”参数用于生成模拟数据。

测试账号:  

演示地址:

vue-access-control.refined-x.com

总结

以上所述是小编给大家介绍的Vue-Access-Control 前端用户权限控制解决方案,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对积木网网站的支持!

使用Vue完成一个简单的todolist的方法 看了两天的Vue,还是上手写一个简单的todolist更实用(文末有彩蛋)。一、使用vue-cli脚手架快速搭建一个框架利用vue-cli来自动生成我们项目的前端目录

Vue按需加载的具体实现 概念(懒加载)当打包构建应用时,JavaScript包会变得非常大,影响页面加载。如果我们能把不同路由对应的组件分割成不同的代码块,然后当路由被访

vue微信分享 vue实现当前页面分享其他页面 本文实例为大家分享了vue微信分享展示的具体代码,供大家参考,具体内容如下首先以分享给朋友为例1、先看官方文档wx.onMenuShareAppMessage({title:'',//分享

标签: Vue-Access-Control 前端用户权限控制解决方案

本文链接地址:https://www.jiuchutong.com/biancheng/378949.html 转载请保留说明!

上一篇:AngularJS2 与 D3.js集成实现自定义可视化的方法

下一篇:使用Vue完成一个简单的todolist的方法(vue如何用)

  • 企业所得税损益结转
  • 缴纳企业所得税会计分录怎么做
  • 补缴关税税率
  • 怎么找高新技术企业的数据
  • 不良资产处置措施
  • 增值税进项发票网上勾选平台
  • 企业贷款合同签订后多久放款
  • 其他应收款怎样做平
  • 未达起征点可以开专票吗
  • 养殖企业如何做销售
  • 确认销售收入的重要依据是什么
  • 制造企业发出材料成本的计价方法
  • 子公司的财报和母公司的财报并表吗
  • 私车公用产生的过路费开个人发票还是公司发票
  • 起征点与免征额的区别
  • 专用发票可以下账吗
  • 挂靠人员帮外单位人员缴纳社保如何做账
  • 加油的时候可以开发票吗
  • 增值税发票查验平台显示查无此票
  • 车改补贴是否计入工资总额
  • 收入和成本都是真实发生的但是不匹配
  • 环保税计入项目成本吗
  • 贷款服务开票开具要求
  • 财政拨款收入如何记账
  • 诉讼过程中
  • 外贸出口企业退税计算
  • 合并报表六大抵消分录通俗理解
  • 销售部门的固定资产折旧计入什么科目
  • 在公司预支费用怎么写单据
  • 企业所得税预缴可以不交吗
  • phpwind教程
  • windows11怎么查询激活时间
  • 取得企业债券利息为什么要交个人所得税
  • yolov5使用教程
  • 登记总账的科目有哪些
  • 公司支付的工伤赔偿金可以税前扣除吗
  • framework怎么用
  • vue–router
  • 缴纳医疗保险费会计分录
  • 小微企业所得税优惠政策2023
  • 红字更正法和红字冲销的区别
  • 记账凭证的记账符号要打勾吗
  • 企业职工薪酬如何确定
  • mongodb部署安装
  • 一次性开票分期确认收入如何纳税申报
  • sql2000日志清理
  • 购买的软件属于什么资产
  • 设计公司成本核算分录
  • 消费税和购置税系重复征税
  • 企业所得税汇算表
  • 中小创投企业收益分析
  • 资产减值损失的科目编码
  • 稽查跨年进项税额转出要调整所得税吗
  • 公司送的车还能要回去吗
  • 登记账簿遇到的问题及解决
  • 防伪标内容
  • 办公室做隔断多少钱
  • 物流运输业务
  • 劳务派遣期限是什么意思
  • 培训公司会计账务处理
  • 加班餐补需要发票嘛
  • 什么是固定资产的后续支出
  • 公司买车可以抵税几年
  • mysql unique option prefix myisam_recover instead of myisam-recover-options的解决方法
  • 存储过程怎么理解
  • Linux下MySQL5.7.18 yum方式从卸载到安装过程图解
  • win7鼠标右键一闪就没了
  • 电脑windowxp系统重装
  • macbook桌面2
  • Win RT 8.1 Update 3怎么提前更新安装使用?
  • centos如何安装yum
  • linux常用命令useradd
  • jquery多选
  • jquery1.8
  • 用js实现导航栏的下拉列表
  • jquery代码实现鼠标点击
  • 阿里大于短信验证接口
  • pythonglobal用法
  • 动态生成script
  • 西安税务机关
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设