refactor: 优化401/403错误处理逻辑,更符合常理
核心改进: - 401错误:先尝试刷新token,刷新成功则标记后返回null交由上层重试 - 403错误:直接跳转到登录页 - 移除无用的options和httpClient参数 - 简化层次:client.js(清理) -> http.js(业务) -> AuthService(刷新) 具体变更: 1. client.js: handle401Error()只清空token,不处理重定向 2. http.js: - 401优先尝试刷新,失败才跳转登录页 - 403直接跳转登录页 3. AuthService.js: - 刷新成功:标记error._handled=true, error._tokenRefreshed=true,返回null - 刷新失败:调用回调后抛出错误,交由上层处理跳转 - 移除options和httpClient参数 逻辑更清晰:client清理token -> http处理逻辑 -> AuthService刷新token,职责分明 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
@@ -30,19 +30,22 @@ function isInWhiteList(url) {
|
||||
|
||||
/**
|
||||
* 处理 401 未授权错误
|
||||
* 注意:只做清理工作,不处理重定向(重定向由上层回调处理)
|
||||
*/
|
||||
let isHandling401 = false
|
||||
function handle401Error() {
|
||||
function handle401Error(error) {
|
||||
if (isHandling401) return
|
||||
|
||||
|
||||
isHandling401 = true
|
||||
|
||||
|
||||
try {
|
||||
// 清空token
|
||||
tokenManager.clearTokens()
|
||||
console.warn('Token已清空,因401错误')
|
||||
} catch (e) {
|
||||
console.error('清空 token 失败:', e)
|
||||
}
|
||||
|
||||
|
||||
// 延迟重置标志
|
||||
setTimeout(() => {
|
||||
isHandling401 = false
|
||||
|
||||
Reference in New Issue
Block a user