位置: 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自动化测试平台)

  • 华为手机关机怎么查定位追踪(华为手机关机怎么定位)

    华为手机关机怎么查定位追踪(华为手机关机怎么定位)

  • 返利网怎么返利(返利网返利的钱谁出的)

    返利网怎么返利(返利网返利的钱谁出的)

  • oppo手机怎么打开隐藏图标(oppo手机怎么打不出电话怎么回事)

    oppo手机怎么打开隐藏图标(oppo手机怎么打不出电话怎么回事)

  • 无线网络图标上有个叉(无线网络图标上有个感叹号怎么解决)

    无线网络图标上有个叉(无线网络图标上有个感叹号怎么解决)

  • 腾讯会议共享屏幕黑屏(腾讯会议共享屏幕时怎么露脸)

    腾讯会议共享屏幕黑屏(腾讯会议共享屏幕时怎么露脸)

  • 错误码110509是什么意思(错误码110519)

    错误码110509是什么意思(错误码110519)

  • 抖音怎么买僵尸粉?(抖音怎么买僵尸号)

    抖音怎么买僵尸粉?(抖音怎么买僵尸号)

  • 手机带pro和不带pro有什么区别(手机带pro和不带pro)

    手机带pro和不带pro有什么区别(手机带pro和不带pro)

  • 表示主程序结束的功能指令是(表示主程序结束的指令是哪一个)

    表示主程序结束的功能指令是(表示主程序结束的指令是哪一个)

  • wps英文版怎么转换为中文版(wps英文版怎么转换为中文版视频)

    wps英文版怎么转换为中文版(wps英文版怎么转换为中文版视频)

  • 一个手机号可以注册几个快手(一个手机号可以注册几个支付宝)

    一个手机号可以注册几个快手(一个手机号可以注册几个支付宝)

  • 华为inetl00是什么型号(华为手机inetl00)

    华为inetl00是什么型号(华为手机inetl00)

  • 已丢失网络连接什么意思(已丢失网络连接safari)

    已丢失网络连接什么意思(已丢失网络连接safari)

  • 压缩包是什么可以删吗(压缩包是啥)

    压缩包是什么可以删吗(压缩包是啥)

  • airpods2防水等级(苹果耳机airpods二代防水等级)

    airpods2防水等级(苹果耳机airpods二代防水等级)

  • 小米未知来源怎么设置(小米未知来源怎么关闭)

    小米未知来源怎么设置(小米未知来源怎么关闭)

  • 三星手机怎么截屏(三星手机怎么截图快捷键)

    三星手机怎么截屏(三星手机怎么截图快捷键)

  • 快手发作品审核多久(快手发作品审核的是真人吗)

    快手发作品审核多久(快手发作品审核的是真人吗)

  • beats蓝牙耳机怎么看电量(beats蓝牙耳机怎么配对新手机)

    beats蓝牙耳机怎么看电量(beats蓝牙耳机怎么配对新手机)

  • 扫描付款码如何设密码(扫码付款的二维码怎么弄)

    扫描付款码如何设密码(扫码付款的二维码怎么弄)

  • 重装系统后分辨率不对怎么办(重装系统后分辨率1920x1080不见了)

    重装系统后分辨率不对怎么办(重装系统后分辨率1920x1080不见了)

  • 抖音自动抢福袋脚本 直播间全自动辅助软件(抖音自动抢福袋挂机软件哪个好)

    抖音自动抢福袋脚本 直播间全自动辅助软件(抖音自动抢福袋挂机软件哪个好)

  • 自查补报以前年度收入可以补在当前属期吗
  • 注册资本没有到位可以注销吗
  • 什么是税收滞纳金请举例说明
  • 财务记录软件
  • 经营活动现金流量公式
  • 飞机票火车票汽车票抵扣进项税
  • 应交增值税减免税款怎么结转
  • 企业重组个人股东个人所得税
  • 小规模纳税人开票税率
  • 幼儿园收取生活费通知
  • 销售边角料计入什么科目
  • 赞助给客户年节祝福语
  • 地税迁移期间能开发票吗
  • 工业印花税核定比例
  • 计提坏账损失纳税的调整
  • 广告服务增值税差额征税
  • 企业捐赠扣除
  • 母公司开票给子公司有什么税务风险吗
  • 事业单位 年终
  • 集团公司股份
  • 贸易公司出口是什么意思
  • 预付办公用品费用,未收到发票
  • 没收到电费账单怎么办
  • 不用命令打开组策略
  • 长期借款和短期借款会计分录的区别
  • win10默认网关不可用总掉线解决方法
  • 代理买卖证券款属于什么科目
  • 估价入库金额怎么来
  • php 调试工具
  • 时间序列多步预测方法
  • html导航栏边框
  • ppp中启用chap命令
  • 银行代发工资会扣个人所得税吗
  • 假发票如何举报
  • 企业所得税核查报告
  • 商场返点怎么核算
  • 支付贷款利息属于筹资活动吗
  • 收益相关的政府补助账务处理
  • 购买商品优惠怎么做账
  • 其他科技推广服务业可以加计扣除吗
  • 发票没拿回来可以报销吗
  • 实收资本可以用于偿还借款
  • SQL Server Management Studio教程
  • 专票丢了重开需要交钱吗
  • 当月销售次月开票怎么做账
  • 小微企业免征增值税优惠政策
  • 资本公积的用途主要用于
  • 小规模纳税人加工劳务的税率是多少
  • 速动比率和流动比率的关系
  • 资产负债表日后非调整事项应当在附注中披露
  • 工程物资是
  • 一般纳税人出现以下哪些情况时,其进项税额不得抵扣( )
  • 净现值率和现值指数与净现值什么时候它们评价结果一致
  • 简易计税项目可以抵扣进项税吗?
  • 账本页面设置
  • mysql8.0设置字符集编码
  • 在mysql中使用视图的限制
  • 网站windows
  • win8无线网受限
  • 苹果7开发者模式怎么打开
  • 微软推送windows 11
  • lumia1020手机
  • Windows Server 2012服务器管理器的详细介绍
  • win7任务栏显示预览窗口
  • win10以太网属性为空白怎么办
  • win7系统笔记本怎么调节电脑亮度
  • win8个性化外观恢复默认设置
  • js函数详解
  • jqueryui
  • jquery-easyui-1.3.3
  • Linux 中的nc命令小结
  • javascript数据类型有哪些
  • node.js nvm
  • js闭包的定义和用途
  • 2023年惠州契税最新规定
  • 国家税务总局惠州仲恺高新技术产业开发区税务局
  • 所得税季度预缴申报表怎样填写
  • 办理税务需要开户许可证吗
  • 税控ic卡就是税控盘吗
  • 龙岗区龙岗税务局地址
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设