This commit is contained in:
2025-08-15 16:51:24 +08:00
parent 8e4f51500f
commit 657c426d9b
5 changed files with 52 additions and 715 deletions

View File

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

View File

@@ -1,7 +1,7 @@
import { getTokenKeySessionStorage } from "@/utils/auth";
// 使用环境变量配置基础URL
const BASE_URL = process.env.VUE_APP_API_BASE_URL || "http://localhost:8088";
const BASE_URL = null;
/**
* 创建聊天流式连接
@@ -16,7 +16,7 @@ export function createChatStream(params) {
const requestId = `req-${Date.now()}-${Math.random()
.toString(36)
.slice(2, 8)}`;
const url = `${BASE_URL}/aitutor/aichat/stream`;
const url = `${process.env.VUE_APP_BASE_API}/aitutor/aichat/stream`;
const token = getTokenKeySessionStorage();
if (!token) {