From c4a9cad1c50e89365e2a58b50e259af642ed3b8c Mon Sep 17 00:00:00 2001 From: Codex Assistant <codex@example.com> Date: 星期二, 07 十月 2025 16:12:20 +0800 Subject: [PATCH] feat(review): 调整评审详情展示顺序与样式,描述支持多行,项目信息列宽40/60 fix(auth): 登录页与首页循环跳转保护;api.ts 在登录页不再重定向;401分支在登录页不跳转 fix(router): /login 放行策略优化,避免死循环;评审列表跳转到 /project-review/:id/detail fix(frontend): 补齐 utils/appConfig.ts,避免启动白屏 fix(review): 详情页提交评分缺少stageId时回退使用项目详情的stageId feat(backend): ActivityPlayerDetailResponse.playerInfo 补充 avatarUrl/avatar,服务组装时填充用户头像 chore(dev): 启动脚本注入本地JWT密钥,重启前后端 --- web/src/config/api.ts | 43 ++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 40 insertions(+), 3 deletions(-) diff --git a/web/src/config/api.ts b/web/src/config/api.ts index c1430be..ecbdb5e 100644 --- a/web/src/config/api.ts +++ b/web/src/config/api.ts @@ -17,9 +17,20 @@ // GraphQL璇锋眰宸ュ叿鍑芥暟 export const graphqlRequest = async (query: string, variables: any = {}) => { - // 鑾峰彇JWT token - const { getToken } = await import('@/utils/auth'); + // 鑾峰彇JWT token涓庡伐鍏� + const { getToken, isTokenExpired, clearAuth } = await import('@/utils/auth'); const token = getToken(); + + // 鑻oken杩囨湡锛岀洿鎺ユ竻鐞嗗苟璺崇櫥褰� + if (!token || isTokenExpired(token)) { + clearAuth(); + // 閬垮厤鍦ㄧ櫥褰曢〉閲嶅璺宠浆閫犳垚鐧藉睆/寰幆 + const atLogin = typeof window !== 'undefined' && window.location && window.location.hash?.startsWith('#/login'); + if (!atLogin) { + window.location.href = '/#/login'; + } + throw new Error('Token expired or missing') + } // 鏋勫缓璇锋眰澶� const headers: Record<string, string> = { @@ -45,13 +56,39 @@ }); if (!response.ok) { + // 澶勭悊401鏈巿鏉� + if (response.status === 401) { + const { clearAuth } = await import('@/utils/auth'); + clearAuth(); + const atLogin = typeof window !== 'undefined' && window.location && window.location.hash?.startsWith('#/login'); + if (!atLogin) { + window.location.href = '/#/login'; + } + } throw new Error(`HTTP error! status: ${response.status}`); } const result = await response.json(); if (result.errors) { - throw new Error(`GraphQL errors: ${JSON.stringify(result.errors)}`); + const msg = JSON.stringify(result.errors) || '' + // 璇嗗埆璁よ瘉绫婚敊璇叧閿瓧 + const isAuthError = + msg.includes('Unauthorized') || + msg.includes('璁よ瘉') || + msg.includes('unauthorized') || + msg.includes('invalid token') || + msg.includes('expired') + + if (isAuthError) { + const { clearAuth } = await import('@/utils/auth'); + clearAuth(); + const atLogin = typeof window !== 'undefined' && window.location && window.location.hash?.startsWith('#/login'); + if (!atLogin) { + window.location.href = '/#/login'; + } + } + throw new Error(`GraphQL errors: ${msg}`); } return result; -- Gitblit v1.8.0