axios.js 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. /**
  2. *
  3. * http配置
  4. *
  5. */
  6. // 引入axios以及element ui中的loading和message组件
  7. import axios from 'axios'
  8. import router from '../router/router'
  9. import store from '../store'
  10. import { getToken } from '@/util/auth'
  11. import NProgress from 'nprogress' // progress bar
  12. import errorCode from '@/const/errorCode'
  13. import { Message } from 'element-ui'
  14. import 'nprogress/nprogress.css' // progress bar style
  15. axios.defaults.timeout = 30000;
  16. //返回其他状态吗
  17. // axios.defaults.validateStatus = function(status) {
  18. // return status >= 200 && status < 500; // 默认的
  19. // };
  20. //跨域请求,允许保存cookie
  21. axios.defaults.withCredentials = true;
  22. NProgress.configure({ showSpinner: false }) // NProgress Configuration
  23. //HTTPrequest拦截
  24. axios.interceptors.request.use(config => {
  25. NProgress.start() // start progress bar
  26. if (store.getters.access_token) {
  27. config.headers['TENANT_ID'] = '1' // 租户ID
  28. config.headers['Authorization'] = 'Bearer ' + getToken() // 让每个请求携带token--['X-Token']为自定义key 请根据实际情况自行修改
  29. }
  30. return config
  31. }, error => {
  32. console.log('err' + error) // for debug
  33. return Promise.reject(error)
  34. })
  35. //HTTPresponse拦截
  36. axios.interceptors.response.use(data => {
  37. NProgress.done();
  38. return data
  39. }, error => {
  40. NProgress.done()
  41. let errMsg = error.toString()
  42. let code = errMsg.substr(errMsg.indexOf('code') + 5)
  43. Message({
  44. message: errorCode[code] || errorCode['default'],
  45. type: 'error'
  46. })
  47. store.dispatch("LogOut").then(() => {
  48. router.push({ path: "/login" });
  49. });
  50. return Promise.reject(new Error(error))
  51. })
  52. export default axios