123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142 |
- import axios from 'axios';
- import { ElMessage, ElMessageBox } from 'element-plus';
- import { getOtherServersOrigin } from '/@/utils/origin'
- import { getToken, removeToken } from "/@/utils/auth";
- // 配置新建一个 axios 实例
- const service = axios.create({
- baseURL: getOtherServersOrigin(import.meta.env.VITE_MODBUS_API),
- timeout: 120000,
- headers: { 'Content-Type': 'application/json' },
- });
- // 添加请求拦截器
- service.interceptors.request.use(
- (config) => {
- // 在发送请求之前做些什么 token
- if (getToken()) {
- (<any>config.headers).common['Authorization'] = `Bearer ${getToken()}`;
- }
- return config;
- },
- (error) => {
- // 对请求错误做些什么
- return Promise.reject(error);
- }
- );
- // 添加响应拦截器
- service.interceptors.response.use(
- (response) => {
- // 对响应数据做点什么
- const res = response.data;
- const code = response.data.code
- if (code === 401) {
- ElMessageBox.alert('登录状态已过期,请重新登录', '提示',
- { confirmButtonText: '确定', showCancelButton: false, closeOnHashChange: false, closeOnPressEscape: false, closeOnClickModal: false, showClose: false })
- .then(() => {
- localStorage.clear(); // 清除缓存/token等
- sessionStorage.clear(); // 清除缓存/token等
- removeToken()
- window.location.href = '/'; // 去登录页
- })
- .catch(() => { });
- } else if (code === undefined && res.message === undefined) { // 可能是下载文件
- return response
- } else if (code !== 0) {
- ElMessage.closeAll()
- ElMessage.error(res.message)
- return Promise.reject(new Error(res.message))
- } else {
- // 分页的数据
- if (res.data?.Total !== undefined) {
- return {
- list: res.data.Data,
- total: res.data.Total,
- page: res.data.currentPage,
- ...res.data,
- }
- }
- // if (res.data?.Data) {
- // return res.data.Data
- // }
- if (res.data?.Info && res.data?.Data) { // currentUser接口
- return res.data
- }
- if (res.data?.Data === undefined) {
- return res.data
- }
- return res.data.Data
- }
- },
- (error) => {
- ElMessage.closeAll()
- // 对响应错误做点什么
- if (error.message.indexOf('timeout') != -1) {
- ElMessage.error('网络超时');
- } else if (error.message == 'Network Error') {
- ElMessage.error('网络连接错误');
- } else {
- if (error.response.data) ElMessage.error(error.response.statusText);
- else ElMessage.error('接口路径找不到');
- }
- return Promise.reject(error);
- }
- );
- // 导出 axios 实例
- export default service;
- export function get(url: string, params?: any, config?: any): any {
- return service({
- url,
- method: "get",
- ...config,
- params
- })
- }
- export function post(url: string, data?: any, config?: any): any {
- return service({
- url,
- method: "post",
- ...config,
- data
- })
- }
- export function put(url: string, data?: any): any {
- return service({
- url,
- method: "put",
- data
- })
- }
- export function del(url: string, data?: any): any {
- return service({
- url,
- method: "delete",
- data
- })
- }
- export function file(url: string, params?: any, method: 'get' | 'post' = 'get'): any {
- if (method === 'get') {
- return service({
- url,
- method,
- params,
- timeout: 120000,
- responseType: 'arraybuffer',
- });
- } else {
- return service({
- url,
- method,
- timeout: 120000,
- data: params,
- responseType: 'blob',
- });
- }
- }
|