axios.js 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. "use strict";
  2. import Vue from 'vue';
  3. import axios from "axios";
  4. import constants from "@/utils/constants";
  5. import storage from "@/utils/storage";
  6. import { Notification, Loading } from 'element-ui'
  7. import Store from '@/store'
  8. import Api from '@/api'
  9. import Config from '@/config'
  10. import Router from '@/router'
  11. // Full config: https://github.com/axios/axios#request-config
  12. // axios.defaults.baseURL = process.env.baseURL || process.env.apiUrl || '';
  13. // axios.defaults.headers.common['Authorization'] = AUTH_TOKEN;
  14. // axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded';
  15. // 是否正在刷新的标记
  16. let isRefreshing = false
  17. // 重试队列,每一项将是一个待执行的函数形式
  18. let retryRequests = []
  19. let loadingInstance = {}
  20. let config = {
  21. baseURL: Config.baseURL
  22. // timeout: 60 * 1000, // Timeout
  23. // withCredentials: true, // Check cross-site Access-Control
  24. };
  25. const _axios = axios.create(config);
  26. _axios.interceptors.request.use(
  27. function (config) {
  28. // Do something before request is sent
  29. const token = storage.getStr(constants.token)
  30. if (token) {
  31. // config.headers[constants.tokenHeader] = token
  32. }
  33. config.headers['x-project-id'] = Store.getters.projectId || ''
  34. if (config.loading) {
  35. loadingInstance = Loading.service({})
  36. }
  37. // console.log(config)
  38. return config;
  39. },
  40. function (error) {
  41. // Do something with request error
  42. return Promise.reject(error);
  43. }
  44. );
  45. // Add a response interceptor
  46. _axios.interceptors.response.use(
  47. function (response) {
  48. const config = response.config
  49. if (config.loading) {
  50. loadingInstance.close()
  51. }
  52. let { code, message } = response.data
  53. if (code === 200 || config.responseType === 'blob') {
  54. isRefreshing = false
  55. return response.data
  56. }
  57. if (code === 401) {
  58. Router.push({
  59. path: `/login`
  60. }).then(r => {})
  61. return Promise.reject(response.data)
  62. }
  63. if (code === 402 || code===201) {
  64. Notification.error({
  65. title: '权限不足',
  66. message: message
  67. })
  68. return Promise.reject(response.data)
  69. }
  70. if(code == 806){
  71. Notification.error({
  72. title: '账号未启用',
  73. message: message
  74. })
  75. return Promise.reject(response.data)
  76. }
  77. if (code === 500) {
  78. // TODO
  79. return Promise.reject(response.data)
  80. } else if (code === 0) {
  81. isRefreshing = false
  82. Notification.error({
  83. title: '请求错误',
  84. message: message
  85. })
  86. return Promise.reject(response.data)
  87. } else if (code !== 401) {
  88. }
  89. // Do something with response data
  90. // return response;
  91. },
  92. function (error) {
  93. // Do something with response error
  94. Notification.error({
  95. title: '系统错误',
  96. message: error.response.data.message
  97. })
  98. isRefreshing = false
  99. return Promise.reject(error);
  100. }
  101. );
  102. Plugin.install = function (Vue) {
  103. Vue.axios = _axios;
  104. window.axios = _axios;
  105. Object.defineProperties(Vue.prototype, {
  106. axios: {
  107. get() {
  108. return _axios;
  109. }
  110. },
  111. $axios: {
  112. get() {
  113. return _axios;
  114. }
  115. },
  116. });
  117. };
  118. Vue.use(Plugin)
  119. export default _axios;