美文网首页
前端权限控制-基于vue-router的动态路由实现

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

作者: LongfeiSong | 来源:发表于2020-11-08 22:29 被阅读0次

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

    // router.js

    import Vue from 'vue'

    import Router from 'vue-router'

    Vue.use(Router)

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

    export default 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')

        }

      ]

    })

    登录成功后通过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);

    }

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

    相关文章

      网友评论

          本文标题:前端权限控制-基于vue-router的动态路由实现

          本文链接:https://www.haomeiwen.com/subject/xcdkbktx.html