【面试题】面试官: Vue如何实现权限管理?

news/2024/5/19 12:04:43/文章来源:https://blog.csdn.net/weixin_42981560/article/details/127084983

我正在参加「掘金·启航计划」

一、权限管理

权限管理就是让不同的用户只能访问自己权限内的资源,有以下几种

  • 路由权限,用户登录后只能看到自己权限内的导航菜单,且只能访问自己权限内的路由地址
  • 视图权限,用户只能看到自己权限内的内容和按钮
  • 请求权限,越权请求将其拦截

二、控制权限

  • 接口权限
  • 按钮权限
  • 菜单权限
  • 路由权限

接口权限

用户登录成功后可以得到一个token,将token存起来,通过axios请求拦截器进行拦截,请求头里要携带token

axios.interceptors.request.use(config => {config.headers['token'] = cookie.get('token')return config
})
axios.interceptors.response.use(res=>{},{response}=>{if (response.data.code === 203) { // 登录过期router.push('/login')}
})

路由权限控制

方法一

在路由初始化的时候挂载全部路由,在路由上标记相应的权限信息,当路由跳转的时候做校验

const router = [{path: 'home',component: () => import('@/views/home'),name: 'homePage',meta: {title: '主页',roles: ['admin','editor'] }
}]

缺点:

  • 会加载所有的路由,当路由很多的时候,对性能会有影响;
  • 每次路由跳转都要做权限判断;
  • 菜单信息写在前端,需要修改标题的时候,需要重新编译;
  • 菜单跟路由耦合在一起,路由不一定作为菜单显示,还要多加字段进行标识

方法二

初始化的时候先挂载不需要权限控制的路由,例如登录页。如果用户通过URL访问,则会跳转到404页面

登录后,获取用户的权限信息,然后筛选有权限访问的路由,在全局路由守卫里进行调用addRoutes添加路由

function hasPermission(roles, permissionRoles) {if (roles.indexOf('admin') >= 0) return trueif (!permissionRoles) return truereturn roles.some(role => permissionRoles.indexOf(role) >= 0)
}const whiteList = ['/login', '/getMenuLis']
router.beforeEach((to, from, next) => {if (getToken()) {if (to.path === '/login') {next({ path: '/' })} else {if (store.getters.roles.length === 0) {store.dispatch('GetUserInfo').then(res => {const roles = res.data.roles store.dispatch('GetRoutes', { roles }).then(() => { router.addRoutes(store.getters.addRouters)next({ ...to, replace: true })})}).catch((err) => {store.dispatch('logOut').then(() => {Message.error(err)next({ path: '/' })})})} else {if (hasPermission(store.getters.roles, to.meta.roles)) {next()} else {next({ path: '/401', replace: true, query: { noGoBack: true }})}}}} else {if (whiteList.indexOf(to.path) !== -1) {next()} else {next('/login')}}
})

缺点:

  • 全局路由守卫里,每次路由跳转都要做判断
  • 菜单信息在前端,要修改个标题,需要重新编译
  • 菜单跟路由耦合在一起,路由不一定作为菜单显示,还要多加字段进行标识

菜单权限

菜单权限可以理解成将页面与路由进行解耦

方法一

菜单与路由分离,菜单由后端返回

  1. 前端定义路由信息
{name: "login",path: "/login",component: () => import("@/pages/Login.vue")
}

name字段作为和后端返回的菜单的唯一标识

  1. 全局路由守卫里做判断
function hasPermission(router, accessMenu) {if (whiteList.indexOf(router.path) !== -1) {return true;}let menu = Util.getMenuByName(router.name, accessMenu);if (menu.name) {return true;}return false;
}Router.beforeEach(async (to, from, next) => {if (getToken()) {let userInfo = store.state.user.userInfo;if (!userInfo.name) {try {await store.dispatch("GetUserInfo")await store.dispatch('updateAccessMenu')if (to.path === '/login') {next({ name: 'home_index' })} else {next({ ...to, replace: true })}}  catch (e) {if (whiteList.indexOf(to.path) !== -1) {next()} else {next('/login')}}} else {if (to.path === '/login') {next({ name: 'home_index' })} else {if (hasPermission(to, store.getters.accessMenu)) {Util.toDefaultPage(store.getters.accessMenu,to, routes, next);} else {next({ path: '/403',replace:true })}}}} else {if (whiteList.indexOf(to.path) !== -1) {next()} else {next('/login')}}let menu = Util.getMenuByName(to.name, store.getters.accessMenu);Util.title(menu.title);
});Router.afterEach((to) => {window.scrollTo(0, 0);
});

每次路由跳转的时候都要判断权限,这里的判断也很简单,因为菜单的name与路由的name是对应的,后端返回的菜单是经过权限过滤的

根据路由name找不到对应的菜单,就表示用户有没权限访问

如果路由很多,可以应用初始化时,只挂载不需要权限控制的路由。拿到后端返回的菜单后,根据菜单与路由的对应关系,筛选出可访问的路由,通过addRoutes动态挂载

缺点:

  • 菜单需要和路由一一对应,前端添加了新功能,需要通过菜单管理功能添加新的菜单,如果菜单配置的不对会导致应用不能正常使用
  • 全局路由守卫里,每次路由跳转都要做判断

方法二

菜单和路由都由后端返回

  1. 前端统一定义路由组件
const Home = () => import("../pages/Home.vue");
const UserInfo = () => import("../pages/UserInfo.vue");
export default {home: Home,userInfo: UserInfo
};
  1. 后端返回路由
[{name: "home",path: "/",component: "home"},{name: "home",path: "/userinfo",component: "userInfo"}
]

将后端返回的路由通过addRoutes动态挂载,需要处理数据,将component字段换成对应的组件,注意嵌套路由的数据遍历

缺点:

  • 全局路由守卫里,每次路由跳转都要做判断
  • 需要前后端完美配合

按钮权限

方法一

v-if判断,当如果页面很多的时候,每个页面都要获取用户权限role和路由表里的meta.btnUse,然后再做判断,比较繁琐

方法二

通过自定义指令进行按钮权限的判断

  1. 首先配置路由
{path: 'venueSetting',component: _import('venue/venueSetting'),name: '场馆设置',meta: {btnUse: ['admin', 'editor']}
},
{path: 'fieldSetting',component: _import('venue/fieldSetting'),name: '场地设置',meta: {btnUse: ['admin']}
}
  1. 自定义权限鉴定指令
const has = Vue.directive('has', {bind: function (el, binding, vnode) {let btnPermissionsArr = [];if(binding.value){btnPermissionsArr = Array.of(binding.value);}else{btnPermissionsArr = vnode.context.$route.meta.btnPermissions;}if (!Vue.prototype.$_has(btnPermissionsArr)) {el.parentNode.removeChild(el);}}
});
// 权限检查方法
Vue.prototype.$_has = function (value) {let isExist = false;// 获取用户按钮权限let btnUseStr = sessionStorage.getItem("btnUse");if (btnUseStr == undefined || btnUseStr == null) {return false;}if (value.indexOf(btnUseStr) > -1) {isExist = true;}return isExist;
};
export {has}

在使用的按钮中引用v-has指令

<el-button @click='editClick' type="primary" v-has>编辑</el-button>

总结

根据具体的项目的方案,选择合适的方案,权限判断需要前后端一起判断。

 

给大家推荐一个实用面试题库

1、前端面试题库 (面试必备)            推荐:★★★★★

地址:前端面试题库

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_15619.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

朗涛任命Juanita Zhang为中国大陆区总经理,Peggy Hon为中国香港区总经理

在迅速发展的消费环境中&#xff0c;带领才华横溢的多元创意团队&#xff0c;持续推动业务发展 &#xff08;中国上海&#xff0c;2022年9月27日&#xff09;近日&#xff0c;全球顶尖的品牌设计与咨询公司朗涛宣布重要人事任命&#xff0c;分别任命Juanita Zhang为中国大陆区总…

Eureka注册不上或注册后IP不对(多网卡的坑)

Eureka注册不上或注册后IP不对&#xff08;多网卡的坑&#xff09; 一、问题发现 ​ 使用SpringCloud一套的微服务项目在开发测试环境都再正常不过了&#xff0c;到生产部署的时候启动服务就死活无法启动&#xff0c;去看启动日志发现&#xff0c;在获取配置中心配置时连接不…

SpringBoot保姆级教程(二)SpringBoot入门

目录 一.通过官网搭建项目 二.通过IDEA脚手架搭建项目 三.SpringBoot项目结构 四.通过Maven搭建项目 五.编写Java代码 一.通过官网搭建项目 接下来我们搭建一个SpringBoot项目&#xff0c;并引入SpringMVC的功能&#xff0c; 首先我们可以通过官网搭建项目&#xff1a; 1 …

MYSQL介绍——数据库的增删改及常用函数

数据操作语言——INSERT语句 Insert 语句可以向数据库中插入数据&#xff0c;可以是一条数据&#xff0c;也可以是多条数据&#xff0c;它有以下语法形式&#xff1a; 下面给出一个插入语法的示例&#xff1a; INSERT INTO t_dept(deptno,dname,loc) VALUES(50,司法部,济南)…

(附源码)springboot篮球场地预约系统 毕业设计 345655

蓝球场地预约系统的设计与实现 摘 要 传统的场地预约需要客户亲自到场地所在位置或指定地点进行&#xff0c;由于预约记录多是认为完成&#xff0c;易于出现错误和漏洞&#xff0c;管理效率低&#xff0c;特别是场地繁杂时&#xff0c;传统的预约方式已经完全不能满足要求。 远…

一文读懂 Handler 消息处理机制(源码实战)

Android 异步消息处理机制解析 Android 中的异步消息处理主要由四个部分组成&#xff0c;Message、Handler、MessageQueue、Looper 但是当我们提到 Android 异步处理机制的时候&#xff0c;我们首先会想到 Handler&#xff0c;而大多数Android 初学者对于 Handler 的作用仅局…

医院患者挂号app(IDEA,SpringBoot,SSM,MySQL)+全套视频教程

【项目功能介绍】 本系统包含后台管理和前端app双端系统&#xff0c;后台管理的功能包含: 登录, 退出, 修改管理员信息(基本信息与头像),资源管理, 角色管理&#xff0c;资源权限分配, 数据字典管理&#xff0c;用户管理,医院管理, 医生管理; app端功能包含医生与患者二种角色…

CNN中添加HOG特征的pytorch实现——基于Alexnet

CNN中添加HOG特征的pytorch实现——基于Alexnet 几天前花了差不多两天时间基本实现了这个需求&#xff0c;经历了从一开始的毫无头绪&#xff0c;到最后对CNN模型 (加载数据集和数据流向) 和HOG特征有了更进一步的理解&#xff0c;实现需求之后又杂七杂八的看了一些相关的文章…

DolphinScheduler 进阶(资源中心)

文章目录内置参数引用依赖资源内置参数 DolphinScheduler 提供了一些时间相关的系统参数&#xff0c;方便定时调度使用。 1&#xff09;基础内置参数 变量名参数说明system.biz.date${system.biz.date}定时时间前一天&#xff0c;格式为 yyyyMMddsystem.biz.curdate${system…

资深腾讯架构师耗时2个月整理的Redis全套学习笔记,涵盖所有核心知识点

Redis 是一个开源、基于内存、使用 C 语言编写的 key-value 数据库&#xff0c;并提供了多种语言的 API。它的数据结构十分丰富&#xff0c;基础数据类型包括&#xff1a;string&#xff08;字符串&#xff09;、list&#xff08;列表&#xff0c;双向链表&#xff09;、hash&a…

18【命令设计模式】

文章目录十八、命令设计模式18.1 命令设计模式简介18.1.1 命令设计模式概述18.1.2 命令设计模式的UML类图18.2 命令设计模式的实现18.3 命令设计模式的优缺点十八、命令设计模式 18.1 命令设计模式简介 18.1.1 命令设计模式概述 命令设计模式&#xff08;Command Pattern&am…

元宇宙人均月入过万?智联报告大揭秘(附下载);华盛顿大学·线性代数进阶课程;电子书·深度神经网络应用(Keras);前沿论文 | ShowMeAI资讯日报

&#x1f440;日报合辑 | &#x1f4c6;电子月刊 | &#x1f514;公众号下载资料 | &#x1f369;韩信子 &#x1f4e2; 人均『月入过万』&#xff1f;元宇宙领域就业现状究竟如何 自2021年元宇宙元年之后&#xff0c;大批元宇宙相关岗位如雨后春笋涌现在市场上。从耳熟能详的…

罗克韦尔 Rockwell RSLogix 500 Crack

罗克韦尔自动化除了提供自动化基础硬件外&#xff0c;还提供大量的软件工具&#xff0c;并在其产品中包含了最新的Microsoft的32位Windows NT及ActiveXTM技术。这些软件为用户采用开放式的工业标准提供方便。另外借助DDE、ActiveX和ODBC兼容技术等&#xff0c;使现场数据能容易…

Chrome 浏览器的 ChromeOptions 参数介绍,selenium 动态渲染必看

背景 在使用 selenium 浏览器渲染技术&#xff0c;爬取网站信息时&#xff0c;默认情况下就是一个普通的纯净的chrome浏览器&#xff0c;而我们平时在使用浏览器时&#xff0c;经常就添加一些插件&#xff0c;扩展&#xff0c;代理之类的应用。相对应的&#xff0c;当我们用ch…

SpringBoot+SpringSecurity+JWT

声明&#xff1a; 该文章为b站博主“三更草堂”视频讲解文档。 视频链接&#xff1a; https://www.bilibili.com/video/BV1mm4y1X7Hc/?spm_id_from333.1007 文章目录SpringSecurity从入门到精通课程介绍0. 简介1. 快速入门1.1 准备工作1.2 引入SpringSecurity2. 认证2.1 登陆校…

Windows系统深度学习Anaconda、PyTorch软件安装教程

1.作者介绍 陈梦丹&#xff0c;女&#xff0c;西安工程大学电子信息学院&#xff0c;2022级研究生&#xff0c;张宏伟人工智能课题组 研究方向&#xff1a;机器视觉与人工智能 电子邮件&#xff1a;1169738496qq.com 安装思路&#xff1a; 根据电脑显卡选择cuda版本&#xf…

软件供应链中代码签名的重要性

你怎麼知道你的代碼是可信的&#xff1f; 在一個難以獲得信任的世界裡&#xff0c;這是一個重要的問題要問自己。 我們如何知道我們正在運行的應用程序、我們正在部署的容器或我們交付給客戶的代碼是真實的&#xff1f; 我們怎麼知道它沒有被篡改&#xff1f; 這一切都歸結為…

VUE3-实习笔记02

本节&#xff1a;ant design 3 的自定义校验规则 这里是获取数据&#xff0c;保存数据&#xff0c;有两个接口&#xff0c;测试邮箱的校验是非必要的&#xff0c;点击“发送测试邮件”才校验&#xff0c;所以规则是要另外加进去的&#xff0c;然后点击保存的时候&#xff0c;把…

python基本操作的作业

查看变量类型的Python内置函数是____。type () 返回单字符在unicode编码表中的值的函数为____。ord() Python中的布尔型只有两个值&#xff0c;分别为&#xff1a;____和____。True 和 False 执行下列语句后&#xff0c;从键盘输入10&#xff0c;程序的结果是&#xff1a; 1…

ActiveReportsJS 在 React 应用程序中添加和自定义查看器

谷歌搜破解版&#xff1a;ActiveReportsJS 3.2中文版是一个客户端报告解决方案&#xff0c;可用于各种不同的前端框架和库。从 vanilla JavaScript 到 NuxtJS&#xff0c;ARJS 在设计应用程序和使用其组件时非常灵活。在本文中&#xff0c;我们将讨论如何通过 Visual Studio Co…