2023-11-30 10:49:45 +08:00
|
|
|
|
//http.ts
|
|
|
|
|
|
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
|
|
|
|
import axios from 'axios'
|
|
|
|
|
|
import NProgress from 'nprogress'
|
2024-12-25 08:52:58 +08:00
|
|
|
|
// import { mainStore } from 'store/main'
|
2023-12-06 15:58:21 +08:00
|
|
|
|
import { ElMessage } from "element-plus";
|
2024-12-05 16:58:35 +08:00
|
|
|
|
import { saveAs } from 'file-saver'
|
2023-12-05 09:45:01 +08:00
|
|
|
|
import router from "@/router"
|
2024-12-25 08:52:58 +08:00
|
|
|
|
// const store = mainStore()
|
|
|
|
|
|
|
2023-11-30 10:49:45 +08:00
|
|
|
|
// const CancelToken = axios.CancelToken
|
|
|
|
|
|
// const source = CancelToken.source()
|
|
|
|
|
|
const baseUrl = import.meta.env.VITE_API_URL
|
2023-12-06 13:40:33 +08:00
|
|
|
|
const VITE_token = import.meta.env.VITE_token
|
2023-12-06 13:45:03 +08:00
|
|
|
|
const VITE_LocalFlag = import.meta.env.VITE_LocalFlag
|
2023-12-06 13:40:33 +08:00
|
|
|
|
|
|
|
|
|
|
const VITE_ENV = import.meta.env.VITE_ENV
|
2023-12-05 09:45:01 +08:00
|
|
|
|
|
2023-11-30 10:49:45 +08:00
|
|
|
|
const service = axios.create({
|
|
|
|
|
|
baseURL: baseUrl,
|
|
|
|
|
|
timeout: 60000
|
|
|
|
|
|
})
|
|
|
|
|
|
|
2024-12-25 08:52:58 +08:00
|
|
|
|
|
2023-11-30 10:49:45 +08:00
|
|
|
|
service.interceptors.request.use(
|
|
|
|
|
|
(config) => {
|
2024-12-25 08:52:58 +08:00
|
|
|
|
config.headers['Authorization'] = localStorage.getItem('tokenNew')
|
2023-11-30 10:49:45 +08:00
|
|
|
|
return config
|
|
|
|
|
|
},
|
|
|
|
|
|
(error) => {
|
|
|
|
|
|
return error
|
|
|
|
|
|
}
|
|
|
|
|
|
)
|
|
|
|
|
|
// 响应拦截
|
|
|
|
|
|
service.interceptors.response.use(
|
|
|
|
|
|
(res) => {
|
2024-11-26 15:38:36 +08:00
|
|
|
|
ElMessage.closeAll()
|
2023-12-05 09:45:01 +08:00
|
|
|
|
const { data } = res
|
2023-12-06 15:58:21 +08:00
|
|
|
|
if (data.code == '200') {
|
2023-12-05 09:45:01 +08:00
|
|
|
|
return data
|
2023-12-06 15:58:21 +08:00
|
|
|
|
} else if (data.code == '403') {
|
2023-12-05 09:45:01 +08:00
|
|
|
|
ElMessage.error('请重新登录')
|
|
|
|
|
|
router.push('/login')
|
2023-12-09 17:00:58 +08:00
|
|
|
|
} else if (data.code == '401') {
|
2023-12-08 10:12:43 +08:00
|
|
|
|
ElMessage.error(data.msg)
|
|
|
|
|
|
router.push('/login')
|
2024-11-26 15:38:36 +08:00
|
|
|
|
} else if (data.code == '500') {
|
2024-12-06 17:48:56 +08:00
|
|
|
|
ElMessage({
|
|
|
|
|
|
type: 'error',
|
|
|
|
|
|
message: data.msg,
|
|
|
|
|
|
duration: 1000,
|
|
|
|
|
|
})
|
2023-12-08 10:12:43 +08:00
|
|
|
|
}
|
|
|
|
|
|
else {
|
2023-12-05 09:45:01 +08:00
|
|
|
|
return data
|
|
|
|
|
|
}
|
2023-11-30 10:49:45 +08:00
|
|
|
|
},
|
|
|
|
|
|
(error) => {
|
2024-12-06 17:48:56 +08:00
|
|
|
|
// ElMessage.error('请求失败')
|
|
|
|
|
|
// console.log('error-异常', error)
|
2023-11-30 10:49:45 +08:00
|
|
|
|
}
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
export function get(url: string, params: any) {
|
|
|
|
|
|
return new Promise((resolve, reject) => {
|
2024-12-25 14:24:34 +08:00
|
|
|
|
// NProgress.start()
|
2023-11-30 10:49:45 +08:00
|
|
|
|
service
|
|
|
|
|
|
.get(url, { params })
|
|
|
|
|
|
.then((res: any) => {
|
|
|
|
|
|
NProgress.done()
|
2023-12-04 10:19:21 +08:00
|
|
|
|
if (res.code == '200') {
|
2023-12-04 10:26:00 +08:00
|
|
|
|
resolve(res)
|
2023-11-30 10:49:45 +08:00
|
|
|
|
} else {
|
2023-12-04 10:26:00 +08:00
|
|
|
|
reject(res)
|
2023-11-30 10:49:45 +08:00
|
|
|
|
}
|
|
|
|
|
|
})
|
|
|
|
|
|
.catch((err) => {
|
2024-12-25 14:24:34 +08:00
|
|
|
|
// NProgress.done()
|
2023-11-30 10:49:45 +08:00
|
|
|
|
reject(err.data)
|
|
|
|
|
|
})
|
|
|
|
|
|
})
|
|
|
|
|
|
}
|
|
|
|
|
|
export function post(url: string, params: any) {
|
|
|
|
|
|
return new Promise((resolve, reject) => {
|
2024-12-25 14:24:34 +08:00
|
|
|
|
// NProgress.start()
|
2023-11-30 10:49:45 +08:00
|
|
|
|
service
|
|
|
|
|
|
.post(url, params, {
|
|
|
|
|
|
headers: { 'Content-Type': 'application/json; charset=utf-8' }
|
|
|
|
|
|
})
|
|
|
|
|
|
.then((res: any) => {
|
|
|
|
|
|
NProgress.done()
|
2023-12-04 10:19:21 +08:00
|
|
|
|
if (res.code == '200') {
|
2023-12-04 13:10:38 +08:00
|
|
|
|
resolve(res)
|
2023-11-30 10:49:45 +08:00
|
|
|
|
} else {
|
2023-12-04 13:10:38 +08:00
|
|
|
|
reject(res)
|
2023-11-30 10:49:45 +08:00
|
|
|
|
}
|
|
|
|
|
|
})
|
|
|
|
|
|
.catch((err) => {
|
2024-12-25 14:24:34 +08:00
|
|
|
|
// NProgress.done()
|
2023-11-30 10:49:45 +08:00
|
|
|
|
reject(err)
|
|
|
|
|
|
})
|
|
|
|
|
|
})
|
|
|
|
|
|
}
|
|
|
|
|
|
export function upload(url: string, params: any) {
|
|
|
|
|
|
const formData = new FormData()
|
|
|
|
|
|
for (const key in params) {
|
|
|
|
|
|
if (Object.prototype.hasOwnProperty.call(params, key)) {
|
|
|
|
|
|
formData.append(key, params[key])
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
|
|
NProgress.start()
|
|
|
|
|
|
service
|
|
|
|
|
|
.post(url, formData, {
|
|
|
|
|
|
headers: { 'Content-Type': 'multipart/form-data' }
|
|
|
|
|
|
})
|
|
|
|
|
|
.then((res: any) => {
|
|
|
|
|
|
NProgress.done()
|
2023-12-04 10:19:21 +08:00
|
|
|
|
if (res.code == '200') {
|
2023-12-04 13:10:38 +08:00
|
|
|
|
resolve(res)
|
2023-11-30 10:49:45 +08:00
|
|
|
|
} else {
|
2023-12-04 13:10:38 +08:00
|
|
|
|
reject(res)
|
2023-11-30 10:49:45 +08:00
|
|
|
|
}
|
|
|
|
|
|
})
|
|
|
|
|
|
.catch((err) => {
|
|
|
|
|
|
NProgress.done()
|
|
|
|
|
|
reject(err.data)
|
|
|
|
|
|
})
|
|
|
|
|
|
})
|
|
|
|
|
|
}
|
2024-12-05 16:58:35 +08:00
|
|
|
|
export function download(url: string, params: any, fileName: string = 'downloaded_file') {
|
2023-11-30 10:49:45 +08:00
|
|
|
|
return new Promise((resolve, reject) => {
|
2024-12-05 16:58:35 +08:00
|
|
|
|
NProgress.start(); // 开始进度条
|
|
|
|
|
|
|
2023-11-30 10:49:45 +08:00
|
|
|
|
service
|
|
|
|
|
|
.post(url, params, {
|
|
|
|
|
|
headers: {
|
|
|
|
|
|
'Content-Type': 'application/x-www-form-urlencoded'
|
|
|
|
|
|
},
|
2024-12-05 16:58:35 +08:00
|
|
|
|
responseType: 'blob' // 请求返回数据类型为 Blob(二进制流)
|
2023-11-30 10:49:45 +08:00
|
|
|
|
})
|
|
|
|
|
|
.then((res: any) => {
|
2024-12-05 16:58:35 +08:00
|
|
|
|
NProgress.done(); // 结束进度条
|
|
|
|
|
|
|
|
|
|
|
|
// 判断返回的内容类型是否是 Blob
|
|
|
|
|
|
const contentType = res.headers['content-type'] || '';
|
|
|
|
|
|
if (!contentType.includes('application/octet-stream') && !contentType.includes('application/pdf')) {
|
|
|
|
|
|
reject('文件类型不正确');
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 处理文件下载
|
|
|
|
|
|
const blob = new Blob([res.data], { type: contentType });
|
|
|
|
|
|
|
|
|
|
|
|
// 使用 file-saver 保存文件
|
|
|
|
|
|
saveAs(blob, fileName);
|
|
|
|
|
|
|
|
|
|
|
|
resolve('文件下载成功');
|
2023-11-30 10:49:45 +08:00
|
|
|
|
})
|
|
|
|
|
|
.catch((err) => {
|
2024-12-05 16:58:35 +08:00
|
|
|
|
NProgress.done(); // 结束进度条
|
|
|
|
|
|
reject(err?.data || '下载失败');
|
|
|
|
|
|
});
|
|
|
|
|
|
});
|
2023-11-30 10:49:45 +08:00
|
|
|
|
}
|
2023-12-06 14:12:36 +08:00
|
|
|
|
|
|
|
|
|
|
export function put(url: string, params: any) {
|
|
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
|
|
NProgress.start()
|
|
|
|
|
|
service
|
|
|
|
|
|
.put(url, params, {
|
|
|
|
|
|
headers: { 'Content-Type': 'application/json; charset=utf-8' }
|
|
|
|
|
|
})
|
|
|
|
|
|
.then((res: any) => {
|
|
|
|
|
|
NProgress.done()
|
|
|
|
|
|
if (res.code == '200') {
|
|
|
|
|
|
resolve(res)
|
|
|
|
|
|
} else {
|
|
|
|
|
|
reject(res)
|
|
|
|
|
|
}
|
|
|
|
|
|
})
|
|
|
|
|
|
.catch((err) => {
|
|
|
|
|
|
NProgress.done()
|
|
|
|
|
|
reject(err)
|
|
|
|
|
|
})
|
|
|
|
|
|
})
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
export function detele(url: string, params: any) {
|
|
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
|
|
NProgress.start()
|
|
|
|
|
|
service
|
|
|
|
|
|
.delete(url, { params })
|
|
|
|
|
|
.then((res: any) => {
|
|
|
|
|
|
NProgress.done()
|
|
|
|
|
|
if (res.code == '200') {
|
|
|
|
|
|
resolve(res)
|
|
|
|
|
|
} else {
|
|
|
|
|
|
reject(res)
|
|
|
|
|
|
}
|
|
|
|
|
|
})
|
|
|
|
|
|
.catch((err) => {
|
|
|
|
|
|
NProgress.done()
|
|
|
|
|
|
reject(err.data)
|
|
|
|
|
|
})
|
|
|
|
|
|
})
|
|
|
|
|
|
}
|