request.ts 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. import axios, { Axios, AxiosRequestConfig } from 'axios';
  2. import { useUserStore } from '@/store/user';
  3. import cache from '@/utils/cache';
  4. export interface MyAxiosPromise<T = any>
  5. extends Promise<{
  6. code: number;
  7. data: T;
  8. message: string;
  9. }> {}
  10. interface MyAxiosInstance extends Axios {
  11. // eslint-disable-next-line
  12. (config: AxiosRequestConfig): MyAxiosPromise;
  13. // eslint-disable-next-line
  14. (url: string, config?: AxiosRequestConfig): MyAxiosPromise;
  15. }
  16. class MyAxios {
  17. // axios 实例
  18. instance: MyAxiosInstance;
  19. constructor(config: AxiosRequestConfig) {
  20. // @ts-ignore
  21. this.instance = axios.create(config);
  22. // 请求拦截器
  23. this.instance.interceptors.request.use(
  24. (cfg) => {
  25. const token = cache.getStorageExp('token');
  26. if (token) {
  27. // eslint-disable-next-line
  28. cfg.headers.Authorization = `Bearer ${token}`;
  29. }
  30. return cfg;
  31. },
  32. (error) => {
  33. console.log(error);
  34. return Promise.reject(error);
  35. }
  36. );
  37. // 响应拦截器
  38. this.instance.interceptors.response.use(
  39. (response) => {
  40. console.log('response.config.url', response.config.url);
  41. console.log('response.data', response.data);
  42. return response.data;
  43. },
  44. (error) => {
  45. console.log('响应拦截到错误', error);
  46. if (error.message.indexOf('timeout') !== -1) {
  47. console.error(error.message);
  48. window.$message.error('请求超时,请重试');
  49. }
  50. const statusCode = error.response.status as number;
  51. const errorResponseData = error.response.data;
  52. const whiteList = ['400', '401', '403', '404'];
  53. if (error.response) {
  54. if (!whiteList.includes(`${statusCode}`)) {
  55. if (statusCode === 500) {
  56. let msg = errorResponseData.message;
  57. if (errorResponseData?.errorCode) {
  58. msg = errorResponseData.error;
  59. }
  60. console.error(msg);
  61. return Promise.reject(msg);
  62. }
  63. console.error(error.message);
  64. return Promise.reject(error);
  65. }
  66. if (statusCode === 400) {
  67. console.error(errorResponseData.message);
  68. window.$message.error(errorResponseData.message);
  69. return Promise.reject(errorResponseData);
  70. }
  71. if (statusCode === 401) {
  72. console.error(errorResponseData.message);
  73. window.$message.error(errorResponseData.message);
  74. const userStore = useUserStore();
  75. userStore.logout();
  76. return Promise.reject(errorResponseData);
  77. }
  78. if (statusCode === 403) {
  79. console.error(errorResponseData.message);
  80. window.$message.error(errorResponseData.message);
  81. return Promise.reject(errorResponseData);
  82. }
  83. if (statusCode === 404) {
  84. console.error(errorResponseData.message);
  85. window.$message.error(errorResponseData.message);
  86. return Promise.reject(errorResponseData);
  87. }
  88. } else {
  89. // 请求超时没有response
  90. console.error(error.message);
  91. return Promise.reject(error.message);
  92. }
  93. }
  94. );
  95. }
  96. get<T = any>(
  97. url: string,
  98. config?: AxiosRequestConfig<any> | undefined
  99. ): MyAxiosPromise<T> {
  100. return this.instance.get(url, config);
  101. }
  102. post<T = any>(
  103. url: string,
  104. data?: {} | undefined,
  105. config?: AxiosRequestConfig
  106. ): MyAxiosPromise<T> {
  107. return this.instance.post(url, data, config);
  108. }
  109. }
  110. export default new MyAxios({
  111. baseURL: '/api',
  112. // baseURL: '/prodapi',
  113. timeout: 1000 * 5,
  114. });