YouChain_WMS_Web/nc_wms_web/src/lib/axios.ts

267 lines
7.6 KiB
TypeScript
Raw Normal View History

2025-03-14 17:13:19 +08:00
/*
* ajax
*
* @Author: 1024-
* @Date: 2022-09-06 20:46:03
* @Wechat: zhuda1024
* @Email: lab1024@163.com
* @Copyright 1024 https://1024lab.net Since 2012
*/
2025-05-10 14:43:49 +08:00
import {message, Modal} from 'ant-design-vue';
2025-03-14 17:13:19 +08:00
import axios from 'axios';
2025-05-10 14:43:49 +08:00
import {localRead} from '/@/utils/local-util';
import {useUserStore} from '/@/store/modules/system/user';
import {decryptData, encryptData} from './encrypt';
import {DATA_TYPE_ENUM} from '../constants/common-const';
2025-03-14 17:13:19 +08:00
import _ from 'lodash';
import LocalStorageKeyConst from '/@/constants/local-storage-key-const.js';
// token的消息头
const TOKEN_HEADER = 'Authorization';
// 创建axios对象
const smartAxios = axios.create({
2025-05-10 14:43:49 +08:00
baseURL: import.meta.env.VITE_APP_API_URL,
2025-03-14 17:13:19 +08:00
});
// 退出系统
function logout() {
2025-05-10 14:43:49 +08:00
useUserStore().logout();
location.href = '/';
2025-03-14 17:13:19 +08:00
}
// ================================= 请求拦截器 =================================
smartAxios.interceptors.request.use(
2025-05-10 14:43:49 +08:00
(config) => {
// 在发送请求之前消息头加入token token
const token = localRead(LocalStorageKeyConst.USER_TOKEN);
if (token) {
config.headers[TOKEN_HEADER] = 'Bearer ' + token;
} else {
delete config.headers[TOKEN_HEADER];
}
return config;
},
(error) => {
// 对请求错误做些什么
return Promise.reject(error);
2025-03-14 17:13:19 +08:00
}
);
// ================================= 响应拦截器 =================================
// 添加响应拦截器
smartAxios.interceptors.response.use(
2025-05-10 14:43:49 +08:00
(response) => {
// 根据content-type ,判断是否为 json 数据
let contentType = response.headers['content-type'] ? response.headers['content-type'] : response.headers['Content-Type'];
if (contentType.indexOf('application/json') === -1) {
return Promise.resolve(response);
}
2025-03-14 17:13:19 +08:00
2025-05-10 14:43:49 +08:00
// 如果是json数据
if (response.data && response.data instanceof Blob) {
return Promise.reject(response.data);
}
2025-03-14 17:13:19 +08:00
2025-05-10 14:43:49 +08:00
// 如果是加密数据
if (response.data.dataType === DATA_TYPE_ENUM.ENCRYPT.value) {
response.data.encryptData = response.data.data;
let decryptStr = decryptData(response.data.data);
if (decryptStr) {
response.data.data = JSON.parse(decryptStr);
}
}
2025-03-14 17:13:19 +08:00
2025-05-10 14:43:49 +08:00
const res = response.data;
if (res.code && res.code !== 1) {
// `token` 过期或者账号已在别处登录
if (res.code === 30007 || res.code === 30008) {
message.destroy();
message.error('您没有登录,请重新登录');
setTimeout(logout, 300);
return Promise.reject(response);
}
// 等保安全的登录提醒
if (res.code === 30010 || res.code === 30011) {
Modal.error({
title: '重要提醒',
content: res.msg,
});
return Promise.reject(response);
}
// 长时间未操作系统,需要重新登录
if (res.code === 30012) {
Modal.error({
title: '重要提醒',
content: res.msg,
onOk: logout,
});
setTimeout(logout, 3000);
return Promise.reject(response);
}
message.destroy();
message.error(res.msg);
return Promise.reject(response);
} else {
return Promise.resolve(res);
}
},
(error) => {
// 对响应错误做点什么
if (error.message.indexOf('timeout') !== -1) {
message.destroy();
message.error('网络超时');
} else if (error.message === 'Network Error') {
message.destroy();
message.error('网络连接错误');
} else if (error.message.indexOf('Request') !== -1) {
message.destroy();
message.error('网络发生错误');
}
return Promise.reject(error);
2025-03-14 17:13:19 +08:00
}
);
// ================================= 对外提供请求方法通用请求get post, 下载download等 =================================
/**
* get
*/
export const getRequest = (url, params) => {
2025-05-10 14:43:49 +08:00
return request({url, method: 'get', params});
2025-03-14 17:13:19 +08:00
};
/**
*
* @param config
*/
export const request = (config) => {
2025-05-10 14:43:49 +08:00
return smartAxios.request(config);
2025-03-14 17:13:19 +08:00
};
/**
* post
*/
2025-03-19 17:45:48 +08:00
export const postRequest = (url, data) => {
2025-05-10 14:43:49 +08:00
return request({
data,
url,
method: 'post',
});
2025-03-14 17:13:19 +08:00
};
// ================================= 加密 =================================
/**
* post
*/
export const postEncryptRequest = (url, data) => {
2025-05-10 14:43:49 +08:00
return request({
data: {encryptData: encryptData(data)},
url,
method: 'post',
});
2025-03-14 17:13:19 +08:00
};
// ================================= 下载 =================================
export const postDownload = function (url, data) {
2025-05-10 14:43:49 +08:00
request({
method: 'post',
url,
data,
responseType: 'blob',
2025-03-14 17:13:19 +08:00
})
2025-05-10 14:43:49 +08:00
.then((data) => {
handleDownloadData(data);
})
.catch((error) => {
handleDownloadError(error);
});
2025-03-14 17:13:19 +08:00
};
/**
*
*/
export const getDownload = function (url, params) {
2025-05-10 14:43:49 +08:00
request({
method: 'get',
url,
params,
responseType: 'blob',
2025-03-14 17:13:19 +08:00
})
2025-05-10 14:43:49 +08:00
.then((data) => {
handleDownloadData(data);
})
.catch((error) => {
handleDownloadError(error);
});
};
export const getDownload2 = function (url: string, params: any, signal?: AbortSignal) {
request({
method: 'get',
url,
params,
responseType: 'blob',
signal // 注入取消信号
})
.then((data) => {
handleDownloadData(data);
})
.catch((error) => {
message.success('取消成功');
});
2025-03-14 17:13:19 +08:00
};
function handleDownloadError(error) {
2025-05-10 14:43:49 +08:00
if (error instanceof Blob) {
const fileReader = new FileReader();
fileReader.readAsText(error);
fileReader.onload = () => {
const msg = fileReader.result;
const jsonMsg = JSON.parse(msg);
message.destroy();
message.error(jsonMsg.msg);
};
} else {
message.destroy();
message.error('网络发生错误', error);
}
2025-03-14 17:13:19 +08:00
}
function handleDownloadData(response) {
2025-05-10 14:43:49 +08:00
if (!response) {
return;
}
// 获取返回类型
let contentType = _.isUndefined(response.headers['content-type']) ? response.headers['Content-Type'] : response.headers['content-type'];
// 构建下载数据
let url = window.URL.createObjectURL(new Blob([response.data], {type: contentType}));
let link = document.createElement('a');
link.style.display = 'none';
link.href = url;
// 从消息头获取文件名
let str = _.isUndefined(response.headers['content-disposition'])
? response.headers['Content-Disposition'].split(';')[1]
: response.headers['content-disposition'].split(';')[1];
let filename = _.isUndefined(str.split('fileName=')[1]) ? str.split('filename=')[1] : str.split('fileName=')[1];
link.setAttribute('download', decodeURIComponent(filename));
// 触发点击下载
document.body.appendChild(link);
link.click();
// 下载完释放
document.body.removeChild(link); // 下载完成移除元素
window.URL.revokeObjectURL(url); // 释放掉blob对象
2025-03-14 17:13:19 +08:00
}