permission.ts 1.6 KB
Newer Older
郝先瑞 已提交
1 2 3
import router from '@/router';
import { ElMessage } from 'element-plus';
import useStore from '@/store';
4
import NProgress from 'nprogress';
郝先瑞 已提交
5 6
import 'nprogress/nprogress.css';
NProgress.configure({ showSpinner: false }); // 进度环显示/隐藏
郝先瑞 已提交
7

郝先瑞 已提交
8
// 白名单路由
9
const whiteList = ['/login'];
10

11
router.beforeEach(async (to, from, next) => {
郝先瑞 已提交
12 13
  NProgress.start();
  const { user, permission } = useStore();
14 15
  const hasToken = user.token;
  if (hasToken) {
郝先瑞 已提交
16 17 18 19 20 21 22
    // 登录成功,跳转到首页
    if (to.path === '/login') {
      next({ path: '/' });
      NProgress.done();
    } else {
      const hasGetUserInfo = user.roles.length > 0;
      if (hasGetUserInfo) {
23
        if (to.matched.length === 0) {
24
          from.name ? next({ name: from.name as any }) : next('/401');
25 26 27
        } else {
          next();
        }
郝先瑞 已提交
28 29 30
      } else {
        try {
          await user.getUserInfo();
31
          const roles = user.roles || ['ROOT'];
郝先瑞 已提交
32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54
          const accessRoutes: any = await permission.generateRoutes(roles);
          accessRoutes.forEach((route: any) => {
            router.addRoute(route);
          });
          next({ ...to, replace: true });
        } catch (error) {
          // 移除 token 并跳转登录页
          await user.resetToken();
          ElMessage.error((error as any) || 'Has Error');
          next(`/login?redirect=${to.path}`);
          NProgress.done();
        }
      }
    }
  } else {
    // 未登录可以访问白名单页面(登录页面)
    if (whiteList.indexOf(to.path) !== -1) {
      next();
    } else {
      next(`/login?redirect=${to.path}`);
      NProgress.done();
    }
  }
郝先瑞 已提交
55
});
56 57

router.afterEach(() => {
郝先瑞 已提交
58
  NProgress.done();
郝先瑞 已提交
59
});