前端权限控制-基于vue-router的动态路由实现

在中后台应用系统开发中,大部分情况下会涉及到用户权限控制,除了后端做权限验证外,前端在用户访问时也需要基于用户权限做相应控制。针对前端使用vue框架的情况,对页面一级的权限控制,常规处理是在页面导航栏通过控制导航显隐控制权限,但在浏览器地址栏输入访问路径依然可以访问,可以用vue-router的动态路由来实现权限控制。

// router.js

import Vue from 'vue'

import Router from 'vue-router'

Vue.use(Router)

// 默认路由只配置无需权限的页面

const createRouter = () =>  new Router({

  mode: 'history',

  base: process.env.BASE_URL,

  routes: [

    {

      path: '/',

      redirect: '/user/login'

    },

    {

      path: '/user/login',

      name: 'login',

      component: () => import('@/views/user/Login.vue')

    }

  ]

})

const router = createRouter();

export function resetRouter() { 

    const newRouter = createRouter();

    router.matcher = newRouter.matcher;

}

export default router;

登录成功后通过addRoutes更新路由配置

import routeConfig from '@/routeConfig'

this.$api.user.login({

  username,

  password

}).then(res => {

  if(res.data.code === 0) {

    // 登录成功,根据返回权限码配置动态路由

    let router = routeConfig();

    router.routes.forEach(route => this.$router.options.routes.push(route));

    // 必须将路由push到options中才生效

    this.$router.addRoutes(router.routes);

  }

})

正常情况下这样就可以实现动态路由控制了,但刷新页面发现会出现404,因为刷新时vue实例重新初始化了,导致动态路由被还原成默认路由,此时需要将权限码存储在本地,在main.js中根据权限码重新生成动态路由

// 刷新页面时根据本地缓存重新生成路由

if(sessionStorage.getItem('permission')) {

  let routerData = routeConfig();

  routerData.routes.forEach(route => router.options.routes.push(route));

  router.addRoutes(routerData.routes);

}

以上步骤基本可以实现动态添加路由并在刷新页面是维持路由状态,但访问根路径会始终跳转到登录页,无法默认跳转到首页,这个问题目前还未想到好的解决方案。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容