request.ts 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. import axios, { AxiosInstance, AxiosRequestConfig, AxiosResponse, AxiosError } from 'axios'
  2. import { Message } from '_c/Message'
  3. import qs from 'qs'
  4. import config from './config'
  5. const { result_code, base_url } = config
  6. export const PATH_URL: string = base_url[process.env.VUE_APP_CURENV as string]
  7. // 创建axios实例
  8. const service: AxiosInstance = axios.create({
  9. baseURL: PATH_URL, // api 的 base_url
  10. timeout: config.request_timeout // 请求超时时间
  11. })
  12. // request拦截器
  13. service.interceptors.request.use(
  14. (config: AxiosRequestConfig) => {
  15. console.log(config)
  16. if (config.method === 'post' && config.headers['Content-Type'] === 'application/x-www-form-urlencoded') {
  17. config.data = qs.stringify(config.data)
  18. }
  19. return config
  20. },
  21. (error: AxiosError) => {
  22. // Do something with request error
  23. console.log(error) // for debug
  24. Promise.reject(error)
  25. }
  26. )
  27. // response 拦截器
  28. service.interceptors.response.use(
  29. (response: AxiosResponse) => {
  30. if (response.data.code === result_code) {
  31. return response.data
  32. } else {
  33. Message.error(response.data.message)
  34. }
  35. },
  36. (error: AxiosError) => {
  37. console.log('err' + error) // for debug
  38. Message.error(error.message)
  39. return Promise.reject(error)
  40. }
  41. )
  42. export default service