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

  • 生活累了心语说说句子(生活累了心语)(生活累了心语说说句子)

    生活累了心语说说句子(生活累了心语)(生活累了心语说说句子)

  • iwatch充电线type-c怎么充电(Iwatch充电线上有mw字样)

    iwatch充电线type-c怎么充电(Iwatch充电线上有mw字样)

  • 微信消息不同步到电脑上的原因是什么(为什么手机和电脑微信消息不同步)

    微信消息不同步到电脑上的原因是什么(为什么手机和电脑微信消息不同步)

  • 荣耀30s支持光学防抖吗(荣耀30s光学变焦)

    荣耀30s支持光学防抖吗(荣耀30s光学变焦)

  • cad正版和盗版的区别(cad正版和盗版的差别)

    cad正版和盗版的区别(cad正版和盗版的差别)

  • iphone8p处理器是a几(iphone8p处理器是A几)

    iphone8p处理器是a几(iphone8p处理器是A几)

  • 钉钉属于腾讯王卡吗(钉钉是不是属于腾讯)

    钉钉属于腾讯王卡吗(钉钉是不是属于腾讯)

  • 移动iptv电视频道打不开

    移动iptv电视频道打不开

  • 苹果耳机保修需要提供什么(苹果耳机保修需要啥)

    苹果耳机保修需要提供什么(苹果耳机保修需要啥)

  • 1200w和1500w电机区别(1200w和1500w电机续航)

    1200w和1500w电机区别(1200w和1500w电机续航)

  • 微信视频响了几声显示对方忙线中(微信视频响了几下显示对方忙线中啥意思)

    微信视频响了几声显示对方忙线中(微信视频响了几下显示对方忙线中啥意思)

  • 电力猫和子母路由区别(电力猫跟路由器怎么接)

    电力猫和子母路由区别(电力猫跟路由器怎么接)

  • 美术字文本和段落文本的区别(美术字文本和段落文本有什么区别?各有什么特点?)

    美术字文本和段落文本的区别(美术字文本和段落文本有什么区别?各有什么特点?)

  • 计算器上ac代表什么(计算器上ac是什么)

    计算器上ac代表什么(计算器上ac是什么)

  • 苹果换id数据还在吗(更换苹果id原手机数据还会保留么)

    苹果换id数据还在吗(更换苹果id原手机数据还会保留么)

  • 苹果蓝牙耳机二代怎么充电(苹果蓝牙耳机二代和三代哪个好用)

    苹果蓝牙耳机二代怎么充电(苹果蓝牙耳机二代和三代哪个好用)

  • 快手上的发现是热门吗(快手发现是什么)

    快手上的发现是热门吗(快手发现是什么)

  • 3dtachi是什么(3d-tlc)

    3dtachi是什么(3d-tlc)

  • 抖音保存到相册失败(抖音保存到相册怎么设置)

    抖音保存到相册失败(抖音保存到相册怎么设置)

  • ppt提示词怎么显示(幻灯片提示词)

    ppt提示词怎么显示(幻灯片提示词)

  • 华为P30?pro天气怎么设置摄氏度(p30pro天气设置)

    华为P30?pro天气怎么设置摄氏度(p30pro天气设置)

  • 华为p20怎么无线投屏电视(华为p20怎么无线反向充电)

    华为p20怎么无线投屏电视(华为p20怎么无线反向充电)

  • aoltpspd.exe是什么进程 aoltpspd是安全的进程吗(auepuc.exe是什么软件)

    aoltpspd.exe是什么进程 aoltpspd是安全的进程吗(auepuc.exe是什么软件)

  • 海康视频WEB插件 V1.5.2 开发总结(海康威视网页插件下载)

    海康视频WEB插件 V1.5.2 开发总结(海康威视网页插件下载)

  • 基于Java+SpringBoot+vue+element驾校管理系统设计和实现

    基于Java+SpringBoot+vue+element驾校管理系统设计和实现

  • 微信小程序详细登录流程(图解+代码流程)(微信小程序详细教程)

    微信小程序详细登录流程(图解+代码流程)(微信小程序详细教程)

  • 企业取得被投资单位的长期股权可以享有
  • 中级会计报名必须用ie浏览器吗
  • 融资租入的固定资产需要计提折旧吗
  • 公司视频宣传制作方案
  • 公司能经营烟草公司吗
  • 作废的发票验旧之后怎么领取新发票
  • 财政拨款收入年底结转到本期盈余
  • 预付冲应付会计分录摘要
  • 土地使用税怎么征收标准
  • 先进制造业企业按照当期可抵扣进项税额
  • 待抵扣进项税额冲回
  • 印花税算错了可以补交吗
  • 仓库货物破损处理方法
  • 公司变卖后员工怎么办
  • 顾客让抹零头应对话术
  • 房地产企业所得税清算条件
  • 车船使用税是否必须交
  • 采用审计软件有什么优缺点
  • 发票拍照打印出来能用吗
  • 进出口免抵退税操作
  • 开发票时已交的税金怎么做帐?
  • yii2.0实现验证用户名与邮箱功能
  • 土地增值税的具体规定
  • 有形动产租赁税收优惠
  • php中imagecreatefromjpeg
  • Thinkphp事务操作实例(推荐)
  • 【torch.nn.Parameter 】参数相关的介绍和使用
  • ntpdate 命令
  • 发票开错需要让客户寄回来吗
  • 35.JavaScript对象和数组的解构赋值基础详解、let陷阱、函数参数解构
  • 利息收入包括
  • 刚成立的新公司怎么报税
  • django中httpresponse
  • java泛型方法的作用
  • 子公司使用母公司固定资产
  • 报销还款人民币是什么意思
  • 预存电费余额怎么突然多了
  • javascript 箭头
  • 总承包可以转包吗
  • 公司福利可以发现金吗
  • sql with as用法详解
  • 生育津贴和产假工资就高原则
  • 办培训机构需要什么条件手续
  • 小规模企业没有账,税务会查账吗
  • 上月账单还未结算完毕
  • 残保金中上年在职职工工资总额
  • 上一年度主营业务成本多计提了
  • 库存商品盘点制度
  • 没有合同的收入能入账吗
  • 车辆检验收费
  • 固定资产暂停使用申请怎么写
  • 库存现金存入银行是什么凭证
  • 专利补贴收入计入什么科目
  • 出租写字楼写字楼
  • 财政补助结转余额在借方还是贷方
  • 企业为什么要设置仓库
  • win7 64位系统关机按钮不见了怎么找回 win7关机按钮设置步骤
  • 如何快速提升花呗额度
  • bios里没有启动项设置
  • winxp怎么改壁纸
  • xp系统优化的方法
  • win7安装flash提示连接失败
  • window mobile系统
  • win10下载英雄联盟运行没反应
  • win7系统耳机设置在哪里
  • win7打开摄像头权限
  • style=display:inline
  • perl脚本执行顺序
  • jQuery Easyui datagrid行内实现【添加】、【编辑】、【上移】、【下移】
  • linux服务器安全攻防
  • js脚本如何获取数据库内容?
  • JavaScript的RequireJS库入门指南
  • js实现简单排列的方法
  • Android的事件处理机制是一种______机制
  • 卸载python后模块库还用卸载吗
  • 电子普票最多领多少
  • 地税局书记是什么级别
  • 国家税务定额发票票样
  • 一般纳税人每月开票金额有限额吗
  • 月收入不足1000
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设