Files
EmailBill/Web/src/api/request.js

92 lines
2.2 KiB
JavaScript
Raw Normal View History

2025-12-25 11:20:56 +08:00
import axios from 'axios'
import { showToast } from 'vant'
2025-12-25 13:27:23 +08:00
import { useAuthStore } from '@/stores/auth'
import router from '@/router'
2025-12-25 11:20:56 +08:00
// 创建 axios 实例
const request = axios.create({
baseURL: import.meta.env.VITE_API_BASE_URL,
timeout: 30000,
headers: {
'Content-Type': 'application/json'
}
})
// 请求拦截器
request.interceptors.request.use(
2026-01-16 11:15:44 +08:00
(config) => {
2025-12-25 13:27:23 +08:00
// 添加 token 认证信息
const authStore = useAuthStore()
if (authStore.token) {
config.headers.Authorization = `Bearer ${authStore.token}`
}
2025-12-25 11:20:56 +08:00
return config
},
2026-01-16 11:15:44 +08:00
(error) => {
2025-12-25 11:20:56 +08:00
console.error('请求错误:', error)
return Promise.reject(error)
}
)
// 响应拦截器
request.interceptors.response.use(
2026-01-16 11:15:44 +08:00
(response) => {
2025-12-25 11:20:56 +08:00
const { data } = response
2026-01-16 11:15:44 +08:00
2025-12-25 11:20:56 +08:00
// 统一处理业务错误
if (data.success === false) {
showToast(data.message || '请求失败')
return Promise.reject(new Error(data.message || '请求失败'))
}
2026-01-16 11:15:44 +08:00
2025-12-25 11:20:56 +08:00
return data
},
2026-01-16 11:15:44 +08:00
(error) => {
2025-12-25 11:20:56 +08:00
console.error('响应错误:', error)
2026-01-16 11:15:44 +08:00
2025-12-25 11:20:56 +08:00
// 统一处理 HTTP 错误
if (error.response) {
const { status, data } = error.response
let message = '请求失败'
2026-01-16 11:15:44 +08:00
2025-12-25 11:20:56 +08:00
switch (status) {
case 400:
message = data?.message || '请求参数错误'
break
case 401: {
2025-12-25 11:20:56 +08:00
message = '未授权,请重新登录'
2025-12-25 13:27:23 +08:00
// 清除登录状态并跳转到登录页
const authStore = useAuthStore()
authStore.logout()
2026-01-16 11:15:44 +08:00
router.push({
name: 'login',
query: { redirect: router.currentRoute.value.fullPath }
})
2025-12-25 11:20:56 +08:00
break
}
2025-12-25 11:20:56 +08:00
case 403:
message = '拒绝访问'
break
case 404:
message = '请求的资源不存在'
break
case 500:
message = '服务器内部错误'
break
default:
message = data?.message || `请求失败 (${status})`
}
2026-01-16 11:15:44 +08:00
2025-12-25 11:20:56 +08:00
showToast(message)
} else if (error.request) {
showToast('网络连接失败,请检查网络')
} else {
showToast(error.message || '请求失败')
}
2026-01-16 11:15:44 +08:00
2025-12-25 11:20:56 +08:00
return Promise.reject(error)
}
)
export default request