From c4938f6f4e839890b032c75c7a57333a6a9157a9 Mon Sep 17 00:00:00 2001
From: peng <peng.com>
Date: 星期四, 06 十一月 2025 17:06:10 +0800
Subject: [PATCH] 添加新闻功能

---
 web/src/router/index.ts |   43 +++++++++++++++++++++++++++++++++++++------
 1 files changed, 37 insertions(+), 6 deletions(-)

diff --git a/web/src/router/index.ts b/web/src/router/index.ts
index 617baaf..01a3721 100644
--- a/web/src/router/index.ts
+++ b/web/src/router/index.ts
@@ -1,5 +1,5 @@
 import { createRouter, createWebHashHistory, RouteRecordRaw } from 'vue-router'
-import { isLoggedIn } from '@/utils/auth'
+import { isLoggedIn, getToken, isTokenExpired } from '@/utils/auth'
 
 const routes: RouteRecordRaw[] = [
   {
@@ -81,6 +81,36 @@
         meta: { title: '璇勫垎璇︽儏', icon: 'Edit' }
       },
       {
+        path: '/news',
+        name: 'News',
+        component: () => import('@/views/news-list.vue'),
+        meta: { title: '鏂伴椈绠$悊', icon: 'Document' }
+      },
+      {
+        path: '/news/new',
+        name: 'NewsCreate',
+        component: () => import('@/views/NewsForm.vue'),
+        meta: { title: '鏂板鏂伴椈', hidden: true }
+      },
+      {
+        path: '/news/edit/:id',
+        name: 'NewsEdit',
+        component: () => import('@/views/NewsForm.vue'),
+        meta: { title: '缂栬緫鏂伴椈', hidden: true }
+      },
+      {
+        path: '/news/list',
+        name: 'NewsListPage',
+        component: () => import('@/views/NewsListPage.vue'),
+        meta: { title: '鏂伴椈鍒楄〃', hidden: true }
+      },
+      {
+        path: '/news/detail/:id',
+        name: 'NewsDetail',
+        component: () => import('@/views/NewsDetail.vue'),
+        meta: { title: '鏂伴椈璇︽儏', hidden: true }
+      },
+      {
         path: '/carousel',
         name: 'Carousel',
         component: () => import('@/views/carousel/index.vue'),
@@ -148,8 +178,9 @@
 router.beforeEach((to, from, next) => {
   // 濡傛灉鏄櫥褰曢〉闈紝鐩存帴鏀捐
   if (to.path === '/login') {
-    // 濡傛灉宸茬粡鐧诲綍锛岄噸瀹氬悜鍒伴椤�
-    if (isLoggedIn()) {
+    // 浠呭湪鈥滄湁token涓旀湭杩囨湡涓旀湰鍦板凡璁板綍鐧诲綍淇℃伅鈥濇椂鎵嶄粠鐧诲綍椤佃烦杞埌棣栭〉
+    const t = getToken()
+    if (t && !isTokenExpired(t) && isLoggedIn()) {
       next('/')
     } else {
       next()
@@ -157,9 +188,9 @@
     return
   }
 
-  // 妫�鏌ユ槸鍚﹀凡鐧诲綍
-  if (!isLoggedIn()) {
-    // 鏈櫥褰曪紝閲嶅畾鍚戝埌鐧诲綍椤�
+  // 妫�鏌ユ槸鍚﹀凡鐧诲綍涓攖oken鏈繃鏈�
+  const token = getToken()
+  if (!token || isTokenExpired(token) || !isLoggedIn()) {
     next('/login')
     return
   }

--
Gitblit v1.8.0