axios的介绍及配置多个服务器url

文章目录

1、常用的默认配置的是:baseURL、method、timeout

① baseURL:设置url的基本结构(请求根地址),域名和协议,再结合属性url某个请求路径,axios会自动将baseURL 和 url 进行拼接,从而得出正确的请求路径。

② method:请求方式 get/post

③ timeout:延时时间(超过多少时间就取消请求)【单位是毫秒】

2、axios配置多个服务器url

javascript 复制代码
// 请求时的基础配置VITE_APP_BASE_URL
export const URLMap = {
  base: import.meta.env.MODE === 'development'
  ? import.meta.env.VITE_APP_BASE_URL
  : (window as any).config.VITE_APP_BASE_URL,
  pdf:import.meta.env.MODE === 'development'
  ? import.meta.env.VITE_APP_BASE_URL_PDF
  : (window as any).config.VITE_APP_BASE_URL_PDF,
}
  
const REQUESTS : Record<string, AxiosInstance> = {}

declare module 'axios' {
  interface AxiosResponse<T = any> {
    errorinfo: null
    doc: any
    time: any
    x: any
    y: any
  }
  export function create(config?: AxiosRequestConfig): AxiosInstance
}

Object.keys(URLMap).forEach((item) => {
    const REQUEST: AxiosInstance = axios.create({
    baseURL: URLMap[item],
    headers: {
      'Content-Type': 'application/json;charset=UTF-8',
    },
    timeout: 300000,
    withCredentials: item === 'data',
  })
  REQUESTS[item] = REQUEST
})


// 请求拦截器
Object.keys(REQUESTS).forEach((item) => {
  REQUESTS[item].interceptors.request.use(async (config: AxiosRequestConfig) => {
    const headerToken = await getToken()
    config.headers = config.headers || {}
    if (headerToken)
      config.headers.Authorization = headerToken
  
    if (config.headers.type === 'form') {
      delete config.headers.type
      config.data = qs.stringify(config.data)
      config.headers['Content-Type'] = 'application/x-www-form-urlencoded'
    }
    return config
  })
})


// 响应拦截器
Object.keys(REQUESTS).forEach((item) => {
  REQUESTS[item].interceptors.response.use(
    async (response: AxiosResponse) => {
      const { status, data = {}, statusText } = response
      const errorText = serverCodeMessage[status] || statusText
      const error = ''
      if (status)
        return Promise.resolve(data)
      message.error(error)
      return Promise.reject(error)
    },
    (error) => {
      message.error(String(new Error(error)))
      return Promise.reject(new Error(error))
    },
  )
})

export default REQUESTS

3、配置api文件

javascript 复制代码
import requests from '@/service/index'

export const getAll = (data: paramsInter) => requests.base({
  url: 'xx/xx',
  method: 'POST',
  data,
})
export const get = (data: paramsInter) => requests.pdf({
  url: 'xx/xx',
  method: 'POST',
  data,
})

这样,不同的接口实现从不同的服务器获取资源

4、文件中使用

javascript 复制代码
import { getAll} from '@/service/xx/index'
onMounted(() => {
  getXX()
})

function getXX() {
  getAll(params).then((res) => {
  // xxx
}
相关推荐
攀登的牵牛花15 小时前
前端向架构突围系列 - 框架设计(七):反应式编程框架Flower的设计
前端·架构
mjhcsp16 小时前
C++ Manacher 算法:原理、实现与应用全解析
java·c++·算法·manacher 算法
Coder_Boy_16 小时前
基于SpringAI的在线考试系统-企业级软件研发工程应用规范案例
java·运维·spring boot·软件工程·devops
佛系打工仔16 小时前
K线绘制前言
前端
indexsunny16 小时前
互联网大厂Java面试实战:微服务、Spring Boot与Kafka在电商场景中的应用
java·spring boot·微服务·面试·kafka·电商
捷米研发三部16 小时前
EtherNet/IP转CAN协议转换网关实现罗克韦尔 PLC与压力传感器通讯在轮胎压力监测系统的应用案例
服务器·网络
SUDO-116 小时前
Spring Boot + Vue 2 的企业级 SaaS 多租户招聘管理系统
java·spring boot·求职招聘·sass
白玉瑕16 小时前
服务器的构成
运维·服务器
sheji341616 小时前
【开题答辩全过程】以 基于spring boot的停车管理系统为例,包含答辩的问题和答案
java·spring boot·后端
重生之后端学习16 小时前
21. 合并两个有序链表
java·算法·leetcode·链表·职场和发展