大屏页面初始化

This commit is contained in:
2026-03-02 13:57:22 +08:00
parent d609cc45f0
commit 1de57f2089
14 changed files with 227 additions and 96 deletions

View File

@@ -10,71 +10,80 @@ const service = axios.create({
}
})
const WHITE_LIST = ['/userLogin', '/register']
const WHITE_LIST = ['userLogin', 'register']
service.interceptors.request.use(
(config) => {
const isWhite = WHITE_LIST.some(item => config.url?.includes(item))
const requestUrl = config.url || '';
const isWhite = WHITE_LIST.some(item => requestUrl.includes(item));
if (isWhite) {
return config
return config;
}
const token = localStorage.getItem('token')
const token = localStorage.getItem('token');
if (!token) {
handleLoginExpired()
return Promise.reject()
handleLoginExpired();
return Promise.reject({ config, message: '未获取到token' });
}
config.headers.Authorization = `Bearer ${token}`
return config
config.headers.Authorization = `Bearer ${token}`;
return config;
},
(error) => {
return Promise.reject(error)
return Promise.reject(error);
}
)
service.interceptors.response.use(
(response) => {
const res = response.data
if (typeof res === 'string' && res.includes('<html>')) {
handleLoginExpired()
return Promise.reject()
}
const res = response.data;
// 1. 处理登录失效
if (res.code === 401) {
handleLoginExpired()
return Promise.reject()
handleLoginExpired();
return Promise.reject(res);
}
if (res.code !== 200) {
ElMessage.error(res.msg || '请求失败')
return Promise.reject(res)
// 2. 处理业务成功
if (res.code === 200) {
return res.data;
}
return res.data
// 3. 处理其他业务错误如500
ElMessage.error(res.msg || '请求失败');
return Promise.reject(res);
},
(error) => {
const isWhite = error.config && WHITE_LIST.some(item => error.config.url?.includes(item))
const requestUrl = error?.config?.url || '';
const isWhite = WHITE_LIST.some(item => requestUrl.includes(item));
if (isWhite) {
ElMessage.error('服务异常')
return Promise.reject(error)
const errMsg = error?.response?.data?.msg || '登录请求失败,请检查网络或账号信息';
ElMessage.error(errMsg);
return Promise.reject(error);
}
if (error.response?.status === 401) {
handleLoginExpired()
return Promise.reject(error)
if (error?.response?.status === 401) {
handleLoginExpired();
return Promise.reject(error);
}
ElMessage.error('请求异常,请稍后重试')
return Promise.reject(error)
if (!error.response) {
ElMessage.error('网络异常,请检查网络连接后重试');
return Promise.reject(error);
}
return Promise.reject(error);
}
)
function handleLoginExpired() {
localStorage.removeItem('token')
localStorage.removeItem('token');
if (router.currentRoute.path !== '/login') {
router.push('/login').catch(() => {})
ElMessage.error('登录已失效,请重新登录')
router.push('/login').catch(() => {});
ElMessage.error('登录已失效,请重新登录');
}
}
export default service
export default service;