位置: IT常识 - 正文

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

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

一、权限管理

推荐整理分享【面试题】面试官: Vue如何实现权限管理?(面试题集锦),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:必看的70道面试题回答,50道面试题,面试题集锦,面试题及最佳答案,面试经典试题,面试题集锦,面试经典试题,面试题及参考答案,内容如对您有帮助,希望把文章链接给更多的朋友!

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

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

用户登录成功后可以得到一个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 true if (!permissionRoles) return true return 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') } }})

缺点:

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

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

方法一

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

前端定义路由信息{ name: "login", path: "/login", component: () => import("@/pages/Login.vue")}【面试题】面试官: Vue如何实现权限管理?(面试题集锦)

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

全局路由守卫里做判断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动态挂载

缺点:

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

方法二

菜单和路由都由后端返回

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

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

缺点:

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

方法一

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

方法二

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

首先配置路由{ path: 'venueSetting', component: _import('venue/venueSetting'), name: '场馆设置', meta: { btnUse: ['admin', 'editor'] }},{ path: 'fieldSetting', component: _import('venue/fieldSetting'), name: '场地设置', meta: { btnUse: ['admin'] }}自定义权限鉴定指令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、前端面试题库 (面试必备)            推荐:★★★★★

地址:前端面试题库

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

上一篇:20分钟上手ES6,不会ES6好意思说自己会JS ?(es6体验)

下一篇:【Web UI自动化测试】Web UI自动化测试之框架篇(全网最全)(web自动化测试平台)

  • 华为手机有红外线功能吗(华为手机有红外线功能在哪里)

    华为手机有红外线功能吗(华为手机有红外线功能在哪里)

  • 华为云服务和百度云盘的区别(华为云和百度云的区别)

    华为云服务和百度云盘的区别(华为云和百度云的区别)

  • 微信表情里的骰子怎么没了(微信表情里的骰子在哪里)

    微信表情里的骰子怎么没了(微信表情里的骰子在哪里)

  • 苹果11屏幕下滑一半怎么办(苹果11屏幕下滑一半作用)

    苹果11屏幕下滑一半怎么办(苹果11屏幕下滑一半作用)

  • 微信怎么改深色模式?微信深色模式的设置方法?具体的步骤方法?(微信怎么改深色8.0.3)

    微信怎么改深色模式?微信深色模式的设置方法?具体的步骤方法?(微信怎么改深色8.0.3)

  • 线上微信账号导流是什么(微信号怎么导出聊天记录)

    线上微信账号导流是什么(微信号怎么导出聊天记录)

  • 3D打印技术还可被称作为(3D打印技术还可以给人类的生活带来哪些惊喜)

    3D打印技术还可被称作为(3D打印技术还可以给人类的生活带来哪些惊喜)

  • 苹果q币能干嘛(苹果手机q币可以用来干嘛)

    苹果q币能干嘛(苹果手机q币可以用来干嘛)

  • 钉钉群不小心移除了怎么办(钉钉群不小心移除家校本)

    钉钉群不小心移除了怎么办(钉钉群不小心移除家校本)

  • 附近的人发送成功却没回应(附近的人发送成功别人收不到)

    附近的人发送成功却没回应(附近的人发送成功别人收不到)

  • iwatch5不能删微信聊天(新版watch5微信删除不了)

    iwatch5不能删微信聊天(新版watch5微信删除不了)

  • 蓝牙耳机自动关机解除(蓝牙耳机自动关机后开不了机)

    蓝牙耳机自动关机解除(蓝牙耳机自动关机后开不了机)

  • 换外屏原彩显示没了(换外屏 原彩)

    换外屏原彩显示没了(换外屏 原彩)

  • 华为屏幕指纹解锁手机有哪些(华为屏幕指纹解锁老是亮,可以关闭吗)

    华为屏幕指纹解锁手机有哪些(华为屏幕指纹解锁老是亮,可以关闭吗)

  • 苹果怎么设置呼叫关机(苹果怎么设置呼出号码用哪个方式)

    苹果怎么设置呼叫关机(苹果怎么设置呼出号码用哪个方式)

  • 华为p40有几个摄像头(华为p40p摄像头几个)

    华为p40有几个摄像头(华为p40p摄像头几个)

  • qq三个皇冠需要多久(3个皇冠qq能卖多少钱)

    qq三个皇冠需要多久(3个皇冠qq能卖多少钱)

  • 黑鲨手机怎么隐藏桌面图标(黑鲨手机怎么隐藏相册)

    黑鲨手机怎么隐藏桌面图标(黑鲨手机怎么隐藏相册)

  • 360关闭u盘写保护(360怎么禁止u盘)

    360关闭u盘写保护(360怎么禁止u盘)

  • 怎么将pr视频导出(怎么将pr视频导出到桌面)

    怎么将pr视频导出(怎么将pr视频导出到桌面)

  • wps怎么批量查找内容(wps怎么批量查找重复的表格)

    wps怎么批量查找内容(wps怎么批量查找重复的表格)

  • 微信登录频繁多久恢复(微信登录频繁多久可以恢复)

    微信登录频繁多久恢复(微信登录频繁多久可以恢复)

  • iphone诊断与用量删除(iphone诊断与用量不见了,分析与改进)

    iphone诊断与用量删除(iphone诊断与用量不见了,分析与改进)

  • 苹果6能定位华为手机吗(苹果手机能定位华为吗)

    苹果6能定位华为手机吗(苹果手机能定位华为吗)

  • r15拉黑名单怎么拉出(拉进黑名单的号码怎么拉出来?)

    r15拉黑名单怎么拉出(拉进黑名单的号码怎么拉出来?)

  • 相机里有个峰值是啥意思(相机里有个峰值什么意思)

    相机里有个峰值是啥意思(相机里有个峰值什么意思)

  • 旺旺id怎么看(怎么查看旺旺id)

    旺旺id怎么看(怎么查看旺旺id)

  • 最右如何去除水印(怎么消除最右的水印)

    最右如何去除水印(怎么消除最右的水印)

  • 闲鱼买家付款了卖家可以取消吗(闲鱼买家付款了卖家可以不卖吗)

    闲鱼买家付款了卖家可以取消吗(闲鱼买家付款了卖家可以不卖吗)

  • 旺旺禁言怎么解除(旺旺禁言多久恢复)

    旺旺禁言怎么解除(旺旺禁言多久恢复)

  • 关于 background-image 渐变gradient()那些事!(关于我和鬼变成家人的那件事)

    关于 background-image 渐变gradient()那些事!(关于我和鬼变成家人的那件事)

  • 土地增值税与增值税
  • 个税申报显示无有效的税费种认定信息已核定
  • 其他收益里的政府补助免税吗
  • 会计哪些账本需要保存
  • 政府补助收入要交印花税吗
  • 新增社保工资填多少好
  • 土地使用权出让金多少钱一平米
  • 支票结算业务流程
  • 电汇凭证如何使用
  • 增值税销项税额在借方还是贷方
  • 冲回存货跌价准备计提递延所得税
  • 上月未抵扣完的进项税额
  • 固定资产报废的账务处理例题
  • 境外企业向境内提供国际运输服务核定征收的企业所得税
  • 个调税手续费会计分录怎么写?
  • 不能取得进项发票但结转成本,税务说明怎么写
  • 堤围工程
  • 通发票备注栏写什么内容
  • 某企业2016年年末经营资产总额为4000万元
  • 以实物投资的税种有哪些
  • 财政收据可以抵税吗
  • 行政单位代管资金怎么做账
  • 普票需要缴纳印花税吗
  • 疫情期间企业应该承担哪些责任
  • 银行存款二级科目怎么增加
  • 银行借款利息支出可以税前扣除吗
  • 如何使用ping命令诊断网络故障
  • 辅助生产车间照明用电计入哪个科目
  • mac怎么彻底删除一个软件
  • PHP:oci_set_edition()的用法_Oracle函数
  • 记账凭证的摘要是什么意思
  • 在win7系统中文件属性有哪些
  • 销售折让负数发票如何入账
  • 职工教育经费超过可以结转以后年度怎么做账
  • php从服务器下载文件
  • ubuntu npm安装
  • 工程未审计资金能支付到多少
  • 固定资产是指什么
  • 加计抵减是适用什么税率
  • php微信公众号开发框架
  • x-s和web_session
  • 应收账款的平均余额怎么计算
  • 稳岗补贴怎么申请步骤
  • 结转销售成本的方法
  • 企业一直亏损老板也赚钱
  • ps里的钢笔工具
  • 国外公司给国内个人汇款
  • 在sqlserver2008中
  • 在mysql中创建数据库和表作业
  • 生产性企业账务处理
  • 分红需要满足的条件包括
  • 丢失增值税专用发票的征管政策
  • 客户给我们的罚款怎么查
  • 收到客户承兑怎么做账
  • 固定资产的折旧年限规定
  • 作废发票丢失怎么补办
  • 利息税额计算公式
  • 32位win7系统多大?
  • 了解的反义词
  • 如何把virtualbox虚拟机里面的文件传到主机
  • ubuntu怎么切换到桌面
  • linux中文件系统
  • 快速批量取关
  • win10使用ie8
  • ext.grid.editorgridpanel
  • bat关闭bat
  • 利用python-Flask框架搭建本地数据可视化网站 原创
  • javascript prototype inheritence
  • 用正则表达式替换掉两汉字间的括号
  • unity3d 脚本
  • 拨号器怎么用
  • js自定义指令
  • jqueryui easyui
  • android图库
  • jq 使用
  • vs开发unity教程
  • javascript基本概念
  • 江苏税务开发票
  • 综合征收和分类征收
  • 资源税谁缴纳
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设