axios.js 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  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. if(response.data == '未登录'){
  80. Router.push({
  81. path: `/login`
  82. }).then(r => {})
  83. }
  84. return Promise.reject(response.data)
  85. } else if (code === 0) {
  86. isRefreshing = false
  87. Notification.error({
  88. title: '请求错误',
  89. message: message
  90. })
  91. return Promise.reject(response.data)
  92. } else if (code !== 401) {
  93. }
  94. // Do something with response data
  95. // return response;
  96. },
  97. function (error) {
  98. if(error.response.status == 404){
  99. Notification.error({
  100. title: '接口不存在',
  101. message: error.response.data.message
  102. })
  103. }else{
  104. // Do something with response error
  105. Notification.error({
  106. title: '系统错误',
  107. message: error.response.data.message
  108. })
  109. }
  110. isRefreshing = false
  111. return Promise.reject(error);
  112. }
  113. );
  114. Plugin.install = function (Vue) {
  115. Vue.axios = _axios;
  116. window.axios = _axios;
  117. Object.defineProperties(Vue.prototype, {
  118. axios: {
  119. get() {
  120. return _axios;
  121. }
  122. },
  123. $axios: {
  124. get() {
  125. return _axios;
  126. }
  127. },
  128. });
  129. };
  130. Vue.use(Plugin)
  131. export default _axios;