mirror of
https://github.com/cool-team-official/cool-admin-vue.git
synced 2025-12-16 08:38:48 +00:00
151 lines
2.8 KiB
TypeScript
151 lines
2.8 KiB
TypeScript
import axios from "axios";
|
|
import NProgress from "nprogress";
|
|
import "nprogress/nprogress.css";
|
|
import { ElMessage } from "element-plus";
|
|
import { isDev, config } from "/@/cool";
|
|
import { storage } from "/@/cool/utils";
|
|
import { useBase } from "/$/base";
|
|
import { router } from "../router";
|
|
|
|
axios.defaults.timeout = 30000;
|
|
axios.defaults.withCredentials = false;
|
|
|
|
NProgress.configure({
|
|
showSpinner: true
|
|
});
|
|
|
|
// 请求队列
|
|
let requests: Array<Function> = [];
|
|
|
|
// Token 是否刷新中
|
|
let isRefreshing = false;
|
|
|
|
// @ts-ignore
|
|
axios.interceptors.request.eject(axios._req);
|
|
|
|
// @ts-ignore
|
|
axios._req = axios.interceptors.request.use(
|
|
(req: any) => {
|
|
const { user } = useBase();
|
|
|
|
if (req.url) {
|
|
// 请求进度条
|
|
if (!config.ignore.NProgress.some((e: string) => req.url.includes(e))) {
|
|
NProgress.start();
|
|
}
|
|
}
|
|
|
|
// 请求信息
|
|
if (isDev) {
|
|
console.group(req.url);
|
|
console.log("method:", req.method);
|
|
console.table("data:", req.method == "get" ? req.params : req.data);
|
|
console.groupEnd();
|
|
}
|
|
|
|
// 验证 token
|
|
if (user.token) {
|
|
// 请求标识
|
|
req.headers["Authorization"] = user.token;
|
|
|
|
if (req.url.includes("refreshToken")) {
|
|
return req;
|
|
}
|
|
|
|
// 判断 token 是否过期
|
|
if (storage.isExpired("token")) {
|
|
// 判断 refreshToken 是否过期
|
|
if (storage.isExpired("refreshToken")) {
|
|
return user.logout();
|
|
}
|
|
|
|
// 是否在刷新中
|
|
if (!isRefreshing) {
|
|
isRefreshing = true;
|
|
|
|
user.refreshToken()
|
|
.then((token: string) => {
|
|
requests.forEach((cb) => cb(token));
|
|
requests = [];
|
|
isRefreshing = false;
|
|
})
|
|
.catch(() => {
|
|
user.clear();
|
|
});
|
|
}
|
|
|
|
return new Promise((resolve) => {
|
|
// 继续请求
|
|
requests.push((token: string) => {
|
|
// 重新设置 token
|
|
req.headers["Authorization"] = token;
|
|
resolve(req);
|
|
});
|
|
});
|
|
}
|
|
}
|
|
|
|
return req;
|
|
},
|
|
(error) => {
|
|
return Promise.reject(error);
|
|
}
|
|
);
|
|
|
|
// 响应
|
|
axios.interceptors.response.use(
|
|
(res) => {
|
|
NProgress.done();
|
|
|
|
if (!res?.data) {
|
|
return res;
|
|
}
|
|
|
|
const { code, data, message } = res.data;
|
|
|
|
if (!code) {
|
|
return res.data;
|
|
}
|
|
|
|
switch (code) {
|
|
case 1000:
|
|
return data;
|
|
default:
|
|
return Promise.reject({ code, message });
|
|
}
|
|
},
|
|
async (error) => {
|
|
NProgress.done();
|
|
|
|
if (error.response) {
|
|
const { status, config } = error.response;
|
|
|
|
if (isDev) {
|
|
ElMessage.error(`${config.url} ${status}`);
|
|
} else {
|
|
switch (status) {
|
|
case 401:
|
|
router.href("401");
|
|
break;
|
|
|
|
case 403:
|
|
router.href("403");
|
|
break;
|
|
|
|
case 500:
|
|
router.href("500");
|
|
break;
|
|
|
|
case 502:
|
|
router.href("502");
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
return Promise.reject({ message: error.message });
|
|
}
|
|
);
|
|
|
|
export default axios;
|