Files
AIGC/demo/frontend/src/api/request.js

124 lines
4.1 KiB
JavaScript
Raw Normal View History

2025-10-21 16:50:33 +08:00
import axios from 'axios'
import { ElMessage } from 'element-plus'
import router from '@/router'
import { getApiBaseURL } from '@/utils/apiHelper'
2025-10-21 16:50:33 +08:00
// 创建axios实例
// 自动检测:如果通过 Nginx 访问(包含 ngrok使用相对路径否则使用完整 URL
2025-10-21 16:50:33 +08:00
const api = axios.create({
baseURL: getApiBaseURL(),
timeout: 900000, // 增加到15分钟适应视频生成时间
2025-10-21 16:50:33 +08:00
withCredentials: true,
maxRedirects: 0, // 不自动跟随重定向手动处理302
2025-10-21 16:50:33 +08:00
headers: {
'Content-Type': 'application/json'
},
validateStatus: function (status) {
// 允许所有状态码包括302让拦截器处理
return status >= 200 && status < 600
2025-10-21 16:50:33 +08:00
}
})
// 请求拦截器
api.interceptors.request.use(
(config) => {
// 使用JWT认证添加Authorization头
const token = sessionStorage.getItem('token')
if (token && token !== 'null' && token.trim() !== '') {
2025-10-21 16:50:33 +08:00
config.headers.Authorization = `Bearer ${token}`
console.log('请求拦截器添加Authorization头token长度:', token.length)
} else {
console.warn('请求拦截器未找到有效的token')
2025-10-21 16:50:33 +08:00
}
return config
},
(error) => {
console.error('请求拦截器错误:', error)
return Promise.reject(error)
}
)
// 响应拦截器
api.interceptors.response.use(
(response) => {
// 检查是否是HTML响应可能是302重定向的结果
if (response.data && typeof response.data === 'string' && response.data.trim().startsWith('<!DOCTYPE')) {
console.error('收到HTML响应可能是认证失败:', response.config.url)
// 清除无效的token并跳转到登录页
sessionStorage.removeItem('token')
sessionStorage.removeItem('user')
// 避免重复跳转
if (router.currentRoute.value.path !== '/login') {
ElMessage.error('认证失败,请重新登录')
router.push('/login')
}
// 返回错误,让调用方知道这是认证失败
return Promise.reject(new Error('认证失败收到HTML响应'))
}
// 检查302重定向
if (response.status === 302) {
console.error('收到302重定向可能是认证失败:', response.config.url)
sessionStorage.removeItem('token')
sessionStorage.removeItem('user')
if (router.currentRoute.value.path !== '/login') {
ElMessage.error('认证失败,请重新登录')
router.push('/login')
}
return Promise.reject(new Error('认证失败302重定向'))
}
// 直接返回response让调用方处理data
return response
2025-10-21 16:50:33 +08:00
},
(error) => {
if (error.response) {
const { status, data } = error.response
// 检查响应数据是否是HTML302重定向的结果
if (data && typeof data === 'string' && data.trim().startsWith('<!DOCTYPE')) {
console.error('收到HTML响应可能是302重定向:', error.config.url)
sessionStorage.removeItem('token')
sessionStorage.removeItem('user')
if (router.currentRoute.value.path !== '/login') {
ElMessage.error('认证失败,请重新登录')
router.push('/login')
}
return Promise.reject(error)
}
2025-10-21 16:50:33 +08:00
switch (status) {
case 401:
case 302:
// 302也可能是认证失败导致的
2025-10-21 16:50:33 +08:00
sessionStorage.removeItem('token')
sessionStorage.removeItem('user')
if (router.currentRoute.value.path !== '/login') {
ElMessage.error('认证失败,请重新登录')
router.push('/login')
}
2025-10-21 16:50:33 +08:00
break
case 403:
ElMessage.error('权限不足')
break
case 404:
ElMessage.error('请求的资源不存在')
break
case 500:
ElMessage.error('服务器内部错误')
break
default:
ElMessage.error(data?.message || '请求失败')
2025-10-21 16:50:33 +08:00
}
} else if (error.request) {
2025-10-21 16:50:33 +08:00
ElMessage.error('网络错误,请检查网络连接')
} else {
ElMessage.error('请求配置错误')
2025-10-21 16:50:33 +08:00
}
return Promise.reject(error)
}
)
export default api