使用Vue的路由权限管理方面的问题(详细教程)

本篇文章主要介绍了关于vue的路由权限管理的示例代码,现在分享给大家,也给大家做个参考。

前言

曾经在工作上对 vue 路由权限管理这方面有过研究,这几天又看到了几篇相关的文章,再加上昨天电面中又再一次提及到,就索性整理了一下自己的一些看法,希望对大家有帮助。

实现

大体上实现的思路很简单,先上图:

立即学习“前端免费学习笔记(深入)”;

使用Vue的路由权限管理方面的问题(详细教程)

无非是将路由配置按用户类型分割为 用户路由 和 基本路由,不同的用户类型可能存在不同的 用户路由,具体依赖实际业务。

用户路由: 当前用户所特有的路由

基本路由:所有用户均可以访问的路由

实现控制的方式分两种:

通过vue-router addRoutes 方法注入路由实现控制
通过vue-router beforeEach 钩子限制路由跳转

addRoutes 方式:

通过请求服务端获取当前用户路由配置,编码为 vue-router 所支持的基本格式(具体如何编码取决于前后端协商好的数据格式),通过调用 this.$router.addRoutes 方法将编码好的用户路由注入到现有的 vue-router 实例中去,以实现用户路由。

beforeEach 方式

通过请求服务端获取当前用户路由配置,通过注册 router.beforeEach 钩子对路由的每次跳转进行管理,每次跳转都进行检查,如果目标路由不存再于 基本路由 和 当前用户的 用户路由 中,取消跳转,转为跳转错误页。

以上两种方式均需要在 vue-router 中配置错误页,以保证用户感知权限不足。

两种方式的原理其实都是一样的,只不过 addRoutes 方式 通过注入路由配置告诉 vue-router :“当前我们就只有这些路由,其它路由地址我们一概不认”,而 beforeEach 则更多的是依赖我们手动去帮 vue-router 辨别什么页面可以去,什么页面不可以去。说白了也就是 自动 与 手动 的差别。说到这,估计大家都会觉得既然是 自动 的,那肯定是 addRoutes 最方便快捷了,还能简化业务代码,笔者一开始也是这么认为的,但是!很多人都忽略了一点:

使用Vue的路由权限管理方面的问题(详细教程)

addRoutes 方法仅仅是帮你注入新的路由,并没有帮你剔除其它路由!

设想存在这么一种情况:用户在自己电脑上登录了管理员账号,这个时候会向路由中注入管理员的路由,然后再退出登录,保持页面不刷新,改用普通用户账号进行登录,这个时候又会向路由中注入普通用户的路由,那么,在路由中将存在两种用户类型的路由,即使用户不感知,通过改变 url,普通用户也可以访问管理员的页面!

对于这个问题,也有一个解决办法:

import Vue from 'vue'import Router from 'vue-router'Vue.use(Router)const createRouter = () => new Router({ mode: 'history', routes: []})const router = createRouter()export function resetRouter () { const newRouter = createRouter() router.matcher = newRouter.matcher}export default router

登录后复制

通过新建一个全新的 Router,然后将新的 Router.matcher 赋给当前页面的管理 Router,以达到更新路由配置的目的。

笔者做了一个小demo,大家可以去体验一下。

关于上述问题,在vue-router 的 github issues 下有过讨论,分别是:

Add option to Reset/Delete Routes #1436

Feature request: replace routes dynamically #1234

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

layui表格checkbox选择全选样式及功能的实例

layui select动态添加option的实例

Bootstrap实现可折叠分组侧边导航菜单

以上就是使用Vue的路由权限管理方面的问题(详细教程)的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2752555.html

(0)
上一篇 2025年3月8日 06:24:52
下一篇 2025年2月17日 23:57:34

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 在ES6箭头函数中有关this方面的问题?

    es6中新增了箭头函数这种语法,箭头函数以其简洁性和方便获取this的特性,接下来通过本文给大家分享es6箭头函数中的this,感兴趣的朋友一起看看吧 简要介绍:箭头函数中的this,指向与一般function定义的函数不同,箭头函数thi…

    编程技术 2025年3月8日
    200
  • 一键开启root权限(快速获取root权限)

    在android系统中,root权限赋予用户深入系统操作和定制的能力。然而,获取root权限通常过程繁琐,让普通用户望而却步。为了简化这一过程,php小编新一将在此文中介绍一种便捷且有效的“一键开启root权限”方法,一步步指导用户轻松获取…

    2025年3月6日
    200
  • php用户权限不足怎么办

    问题:you don’t have permission to access /index.html on this server. 原因:index.html是用root用户建的文件,apache权限不够。 解决方法:更改文件…

    2025年3月5日
    200
  • win10相机麦克风权限被禁用解决方法详解

    在使用我们的win10系统的时候,在某些情况下,我们可能会需要用到win10的相机和麦克风。但是我们在使用的时候提示,权限被关闭了,这是什么原因呢,要怎么去解决呢,快来看看详细的教程吧~ win10相机麦克风权限被关闭怎么办详细教程: 1、…

    2025年3月5日 互联网
    200
  • win11拒绝访问该文件夹解决方法

    有用户在打开或移动、删除某个文件夹的时候,遇到了提示win11拒绝访问该文件夹的问题,不知道怎么解决,其实一般我们只要赋予管理员权限即可。 win11拒绝访问该文件夹: 1、首先右键被拒绝的文件夹,打开“属性” 2、接着进入“安全”,观察下…

    2025年3月5日 互联网
    200
  • centos下php项目没有权限怎么办

    centos下php项目没有权限的解决方法是:首先进入nginx目录下,打开配置文件;然后修改【fastcgi_param PHP_ADMIN_VALUE】;最后重启nginx服务器即可。 本文操作环境:windows10系统、php 7.…

    2025年3月5日
    200
  • win10提示没有权限打开该文件怎么办

    当我们在win10系统中尝试打开文件时,有时会遇到“没有权限”的提示,让人困惑。这时,我们需要寻找解决方案,以便顺利打开文件。php小编新一为您带来一些简单有效的方法,帮助您解决win10提示没有权限打开文件的问题。接下来,让我们一起来看看…

    2025年3月5日 互联网
    200
  • 共享文件夹权限在哪设置? Win10设置共享文件夹只读不能修改权限的技巧

    在win10系统中,设置共享文件夹权限是一个常见需求。有时候我们希望将文件夹设置为只读,其他用户可以查看但不能修改。那么,如何在win10设置共享文件夹只读权限呢?在这篇文章中,php小编小新将为大家介绍win10设置共享文件夹只读权限的技…

    2025年3月5日 互联网
    200
  • 修改hosts文件无权限

    php小编新一为您介绍如何解决修改hosts文件无权限的问题。在windows系统中,hosts文件被保护,如果没有管理员权限,无法直接编辑。解决方法是以管理员身份运行文本编辑器,然后打开hosts文件进行编辑。另外,也可以通过修改文件属性…

    2025年3月5日 互联网
    200
  • win7电脑设置everyone权限方法介绍

    php小编小新为您介绍win7电脑设置everyone权限方法。在windows 7系统中,通过设置everyone权限,可以让所有用户在特定文件或文件夹上具有相同的访问权限,方便管理和共享文件。本文将详细介绍如何在win7电脑上设置eve…

    2025年3月5日 互联网
    200

发表回复

登录后才能评论