Files
zhxg_pc/src/utils/ai_request.js

55 lines
1.2 KiB
JavaScript
Raw Normal View History

2025-08-15 16:51:24 +08:00
import axios from "axios";
import { getTokenKeySessionStorage } from "./auth";
import { useRouter } from "vue-router";
import { showToast } from "@/utils/toast"; // 请替换为你的Toast组件
2025-08-14 15:43:24 +08:00
// 创建axios实例
const service = axios.create({
2025-08-15 16:51:24 +08:00
baseURL: process.env.VUE_APP_API_BASE_URL || 'http://localhost:8088',
timeout: 15000,
headers: {
"Content-Type": "application/json",
},
});
2025-08-14 15:43:24 +08:00
// 请求拦截器
service.interceptors.request.use(
2025-08-15 16:51:24 +08:00
(config) => {
// 从本地存储获取token
const token = getTokenKeySessionStorage();
if (token) {
config.headers.Authorization = `Bearer ${token}`;
2025-08-14 15:43:24 +08:00
}
2025-08-15 16:51:24 +08:00
return config;
},
(error) => {
return Promise.reject(error);
}
);
2025-08-14 15:43:24 +08:00
// 响应拦截器
service.interceptors.response.use(
2025-08-15 16:51:24 +08:00
(response) => {
// 对响应数据做处理
return response.data;
},
(error) => {
const router = useRouter();
2025-08-14 15:43:24 +08:00
2025-08-15 16:51:24 +08:00
// 处理401未授权
if (error.response?.status === 401) {
showToast("登录已过期,请重新登录", "error");
router.push("/login");
}
2025-08-14 15:43:24 +08:00
2025-08-15 16:51:24 +08:00
// 处理其他错误状态码
if (error.response?.status === 500) {
showToast("服务器错误,请稍后再试", "error");
2025-08-14 15:43:24 +08:00
}
2025-08-15 16:51:24 +08:00
return Promise.reject(error);
}
);
export default service;