From 5d0e4bcaf5d44a9ce2ff196e38c77676aa8ea880 Mon Sep 17 00:00:00 2001
From: zhouwx <1175765986@qq.com>
Date: Fri, 12 Jun 2026 16:37:15 +0800
Subject: [PATCH] 中科大支线—添加菜单、角色
---
src/permission.js | 92 +++++++++++++++++++++++++++++++---------------
1 files changed, 62 insertions(+), 30 deletions(-)
diff --git a/src/permission.js b/src/permission.js
index dc79d74..71e2767 100644
--- a/src/permission.js
+++ b/src/permission.js
@@ -11,49 +11,81 @@
NProgress.configure({ showSpinner: false });
-const whiteList = ['/homePage'];
+const whiteList = ['/homePage','/fillForm','/checkProgress','/certPdf'];
router.beforeEach((to, from, next) => {
NProgress.start()
+
if (getToken()) {
to.meta.title && useSettingsStore().setTitle(to.meta.title)
/* has token*/
- // if (to.path === '/homePage') {
- // next({ path: '/' })
- // NProgress.done()
- // } else {
- // if (useUserStore().roles.length === 0) {
- // isRelogin.show = true
- // // 判断当前用户是否已拉取完user_info信息
- // useUserStore().getInfo().then(() => {
- // isRelogin.show = false
- // usePermissionStore().generateRoutes().then(accessRoutes => {
- // // 根据roles权限生成可访问的路由表
- // accessRoutes.forEach(route => {
- // if (!isHttp(route.path)) {
- // router.addRoute(route) // 动态添加可访问路由表
- // }
- // })
- // next({ ...to, replace: true }) // hack方法 确保addRoutes已完成
- // })
- // }).catch(err => {
- // useUserStore().logOut().then(() => {
- // ElMessage.error(err)
- // next({ path: '/' })
- // })
- // })
- // } else {
+ if (to.path === '/homePage') {
+ next({ path: '/' })
+ NProgress.done()
+ } else if (whiteList.indexOf(to.path) !== -1) {
+ next()
+ } else {
+ if (useUserStore().roles.length === 0) {
+ isRelogin.show = true
+ // 判断当前用户是否已拉取完user_info信息
+ useUserStore().getInfo().then(() => {
+
+ isRelogin.show = false
+
+ usePermissionStore().generateRoutes().then(accessRoutes => {
+ // 根据roles权限生成可访问的路由表
+ accessRoutes.forEach(route => {
+ if (!isHttp(route.path)) {
+ router.addRoute(route) // 动态添加可访问路由表
+ }
+ })
+ console.log(to.fullPath,"to.fullPath")
+
+ if (to.fullPath == '/index') {
+ // 当登录之后,直接通过ip地址和端口号访问时,跳转到第一个路由页面indexPage
+ let pathIndex = ''
+ if(accessRoutes.length == 0){
+ ElMessage.warning('当前用户未配置菜单权限,请联系管理员!')
+ next(`/index`)
+ return
+ }
+ const firstRoute = accessRoutes[0]
+ // 👇 新增判断:是否有子菜单
+ if (firstRoute.children && firstRoute.children.length > 0) {
+ // 有二级菜单,走原来的逻辑
+ if (firstRoute.path == '/') {
+ pathIndex = firstRoute.path + firstRoute.children[0].path
+ } else {
+ pathIndex = firstRoute.path + '/' + firstRoute.children[0].path
+ }
+ } else {
+ // 没有二级菜单,直接用一级路由的path
+ pathIndex = firstRoute?.path || '/404'
+ }
+ next({ path: pathIndex, replace: true }) // hack方法 确保addRoutes已完成
+ } else {
+ next({ ...to, replace: true }) // hack方法 确保addRoutes已完成
+ }
+ // next({ ...to, replace: true })
+ // hack方法 确保addRoutes已完成
+ })
+ }).catch(err => {
+ useUserStore().logOut().then(() => {
+ ElMessage.error(err)
+ next({ path: '/' })
+ })
+ })
+ } else {
next()
- // }
- // }
+ }
+ }
} else {
// 没有token
if (whiteList.indexOf(to.path) !== -1) {
// 在免登录白名单,直接进入
next()
} else {
- // next(`/homePage?redirect=${to.fullPath}`) // 否则全部重定向到登录页
- next('/homePage')
+ next(`/homePage?redirect=${to.fullPath}`) // 否则全部重定向到登录页
NProgress.done()
}
}
--
Gitblit v1.9.2