vr-uniapp/src/utils/request.ts

81 lines
2.8 KiB
TypeScript
Raw Normal View History

import axios, { InternalAxiosRequestConfig, AxiosResponse } from 'axios';
import { ElMessage, ElMessageBox, type MessageHandler } from 'element-plus';
2024-08-16 09:16:25 +00:00
import { get_cookie } from './index';
// 提示拦截
let messageInstance: MessageHandler;
const message_error = (info: string) => {
if (messageInstance) {
messageInstance.close();
}
messageInstance = ElMessage.error(info);
};
// 创建一个状态变量来跟踪是否已经弹出了退出登录的弹窗
const isLogoutModalShown = ref(true);
// 创建 axios 实例
const index = window.location.href.lastIndexOf('?s=');
2024-08-16 09:16:25 +00:00
const pro_url = window.location.href.substring(0, index);
const service = axios.create({
baseURL: import.meta.env.VITE_APP_BASE_API == '/dev-api' ? import.meta.env.VITE_APP_BASE_API : pro_url + '?s=',
timeout: 50000,
headers: { 'Content-Type': 'application/json;charset=utf-8' },
});
/** @ts-ignore */
// 请求拦截器
service.interceptors.request.use(
2024-08-26 08:42:11 +00:00
async (config: InternalAxiosRequestConfig) => {
2024-08-16 09:16:25 +00:00
// 如果是本地则使用静态tonken如果是线上则使用cookie的token
const cookie = get_cookie('admin_info');
2024-09-03 09:15:00 +00:00
const symbol = config.url?.includes('?') ? '&' : '?';
if (import.meta.env.VITE_APP_BASE_API == '/dev-api') {
let temp_data = await import(import.meta.env.VITE_APP_BASE_API == '/dev-api' ? '../../temp.d' : '../../temp_pro.d');
2024-09-03 09:15:00 +00:00
config.url = config.url + symbol + 'token=' + temp_data.default.temp_token;
} else {
if (cookie) {
2024-09-03 09:27:17 +00:00
config.url = config.url + '&token=' + JSON.parse(cookie).token;
}
}
return config;
},
(error: any) => {
return Promise.reject(error);
}
);
// 响应拦截器
service.interceptors.response.use(
(response: AxiosResponse) => {
2024-08-30 06:05:07 +00:00
const { code, msg, message, data } = response.data;
2024-08-19 07:01:08 +00:00
if (code == 0) {
return response.data;
2024-08-19 07:11:44 +00:00
} else if (code == -400) {
if (isLogoutModalShown.value) {
isLogoutModalShown.value = false;
ElMessageBox.alert(msg, '温馨提示', {
confirmButtonText: '确定',
showClose: false,
type: 'warning',
}).then(() => {
localStorage.clear(); // @vueuse/core 自动导入
window.location.href = data.logout;
});
}
2024-08-19 07:01:08 +00:00
} else {
message_error(msg || message || '系统出错');
2024-08-19 07:01:08 +00:00
return Promise.reject(new Error(msg || 'Error'));
}
},
(error: any) => {
2024-10-11 08:18:28 +00:00
if (error.response && error.response.data) {
2024-08-30 06:05:07 +00:00
const { msg, message } = error.response.data;
message_error(msg || message || '系统出错');
}
return Promise.reject(error.message);
}
);
// 导出 axios 实例
export default service;