index.ts 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  1. import { merge } from 'lodash'
  2. import configs from '@/config'
  3. import { Axios } from './axios'
  4. import { ContentTypeEnum, RequestCodeEnum, RequestMethodsEnum } from '@/enums/requestEnums'
  5. import type { AxiosHooks } from './type'
  6. import { clearAuthInfo, getToken,getUserId,getBrandId,getHouseId } from '../auth'
  7. import feedback from '../feedback'
  8. import NProgress from 'nprogress'
  9. import { AxiosError, type AxiosRequestConfig } from 'axios'
  10. import router from '@/router'
  11. import { PageEnum } from '@/enums/pageEnum'
  12. // 处理axios的钩子函数
  13. const axiosHooks: AxiosHooks = {
  14. requestInterceptorsHook(config) {
  15. NProgress.start()
  16. const { withToken, isParamsToData } = config.requestOptions
  17. const params = config.params || {}
  18. const headers = config.headers || {}
  19. const userId = getUserId();
  20. const brandId = getBrandId();
  21. const houseId = getHouseId();
  22. headers['userId'] = userId || ""
  23. headers['brandId'] = brandId || ""
  24. headers['houseId'] = houseId || ""
  25. // 添加token
  26. if (withToken) {
  27. const token = getToken();
  28. headers['like-admin'] = token || ""
  29. headers['token'] = token || ""
  30. }
  31. // POST请求下如果无data,则将params视为data
  32. if (
  33. isParamsToData &&
  34. !Reflect.has(config, 'data') &&
  35. config.method?.toUpperCase() === RequestMethodsEnum.POST
  36. ) {
  37. config.data = params
  38. config.data.brandId = brandId
  39. config.data.houseId = houseId
  40. config.params = {}
  41. }
  42. // 如果是GET请求,将brandId和houseId添加到params中
  43. if (config.method?.toLowerCase() === 'get') {
  44. config.params = {
  45. ...config.params,
  46. brandId: brandId,
  47. houseId: houseId
  48. }
  49. }
  50. config.headers = headers
  51. return config
  52. },
  53. requestInterceptorsCatchHook(err) {
  54. NProgress.done()
  55. return err
  56. },
  57. async responseInterceptorsHook(response) {
  58. NProgress.done()
  59. const { isTransformResponse, isReturnDefaultResponse } = response.config.requestOptions
  60. //返回默认响应,当需要获取响应头及其他数据时可使用
  61. if (isReturnDefaultResponse) {
  62. return response
  63. }
  64. // 是否需要对数据进行处理
  65. if (!isTransformResponse) {
  66. return response.data
  67. }
  68. const { code, data, show, msg } = response.data
  69. switch (code) {
  70. case RequestCodeEnum.SUCCESS:
  71. if (show) {
  72. msg && feedback.msgSuccess(msg)
  73. }
  74. return data
  75. case RequestCodeEnum.PARAMS_TYPE_ERROR:
  76. case RequestCodeEnum.PARAMS_VALID_ERROR:
  77. case RequestCodeEnum.REQUEST_METHOD_ERROR:
  78. case RequestCodeEnum.ASSERT_ARGUMENT_ERROR:
  79. case RequestCodeEnum.ASSERT_MYBATIS_ERROR:
  80. case RequestCodeEnum.LOGIN_ACCOUNT_ERROR:
  81. case RequestCodeEnum.LOGIN_DISABLE_ERROR:
  82. case RequestCodeEnum.NO_PERMISSTION:
  83. case RequestCodeEnum.FAILED:
  84. case RequestCodeEnum.SYSTEM_ERROR:
  85. case RequestCodeEnum.VERIFICATION_CODE_ERROR:
  86. msg && feedback.msgError(msg)
  87. return Promise.reject(response.data)
  88. case RequestCodeEnum.TOKEN_INVALID:
  89. case RequestCodeEnum.TOKEN_EMPTY:
  90. case RequestCodeEnum.QUIT:
  91. clearAuthInfo()
  92. // window.close();
  93. // router.push(PageEnum.LOGIN)
  94. return Promise.reject()
  95. default:
  96. return data || response.data
  97. }
  98. },
  99. responseInterceptorsCatchHook(error) {
  100. NProgress.done()
  101. if (error.code !== AxiosError.ERR_CANCELED) {
  102. // axios报错不提示
  103. // error.message && feedback.msgError(error.message)
  104. }
  105. if (error.response && error.response.status === RequestCodeEnum.QUIT) {
  106. clearAuthInfo()
  107. }
  108. return Promise.reject(error)
  109. }
  110. }
  111. const defaultOptions: AxiosRequestConfig = {
  112. timeout: configs.timeout,
  113. // 基础接口地址
  114. baseURL: configs.baseUrl,
  115. headers: { 'Content-Type': ContentTypeEnum.JSON, version: configs.version },
  116. // 处理 axios的钩子函数
  117. axiosHooks: axiosHooks,
  118. // 每个接口可以单独配置
  119. requestOptions: {
  120. // 是否将params视为data参数,仅限post请求
  121. isParamsToData: true,
  122. //是否返回默认的响应
  123. isReturnDefaultResponse: false,
  124. // 需要对返回数据进行处理
  125. isTransformResponse: true,
  126. // 接口拼接地址
  127. urlPrefix: configs.urlPrefix,
  128. // 忽略重复请求
  129. ignoreCancelToken: false,
  130. // 是否携带token
  131. withToken: true,
  132. // 开启请求超时重新发起请求请求机制
  133. isOpenRetry: true,
  134. // 重新请求次数
  135. retryCount: 2
  136. }
  137. }
  138. function createAxios(opt?: Partial<AxiosRequestConfig>) {
  139. return new Axios(
  140. // 深度合并
  141. merge(defaultOptions, opt || {})
  142. )
  143. }
  144. const request = createAxios()
  145. export default request