request.js 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. import axios from 'axios'
  2. import { Message } from 'element-ui'
  3. import { getToken, removeToken } from '@/utils/auth'
  4. import router, { resetRouter } from '@/router'
  5. // create an axios instance
  6. const service = axios.create({
  7. baseURL: process.env.VUE_APP_BASE_API, // url = base url + request url
  8. timeout: 10000 // request timeout
  9. // transformRequest: [function(data) { // 转换数据
  10. // const form = new FormData()
  11. // if (!data) {
  12. // return form
  13. // }
  14. // Object.keys(data).forEach(k => {
  15. // const v = (data[k] !== 0 && !data[k] || data[k] === null ? '' : data[k])
  16. // if (Array.isArray(v) && v !== null) {
  17. // Object.keys(v).forEach(key => {
  18. // const vv = (!v[key] || v[key] === null ? '' : v[key])
  19. // form.append(`${k}[${key}]`, vv)
  20. // })
  21. // } else {
  22. // form.append(k, v)
  23. // }
  24. // })
  25. // return form
  26. // }],
  27. // headers: {
  28. // 'Content-Type': 'application/x-www-form-urlencoded'
  29. // }
  30. })
  31. // request interceptor
  32. service.interceptors.request.use(
  33. config => {
  34. // do something before request is sent
  35. if (getToken()) {
  36. // console.log(config, getToken())
  37. // let each request carry token
  38. // ['X-Token'] is a custom headers key
  39. // please modify it according to the actual situation
  40. config.headers['token'] = getToken()
  41. }
  42. return config
  43. },
  44. error => {
  45. // do something with request error
  46. console.log(error) // for debug
  47. return Promise.reject(error)
  48. }
  49. )
  50. // response interceptor
  51. service.interceptors.response.use(
  52. /**
  53. * If you want to get http information such as headers or status
  54. * Please return response => response
  55. */
  56. /**
  57. * Determine the request status by custom code
  58. * Here is just an example
  59. * You can also judge the status by HTTP Status Code
  60. */
  61. response => {
  62. const res = response.data
  63. // if the custom code is not 20000, it is judged as an error.
  64. if (res.c !== 0) {
  65. Message({
  66. message: 'massage: ' + res.m,
  67. type: 'error',
  68. duration: 3 * 1000
  69. })
  70. if (res.c === 1004) {
  71. removeToken()
  72. resetRouter()
  73. router.push(`/login`)
  74. }
  75. return Promise.reject(new Error(res.m || 'Error'))
  76. } else {
  77. return res
  78. }
  79. },
  80. error => {
  81. console.log('err' + error) // for debug
  82. Message({
  83. message: error.message,
  84. type: 'error',
  85. duration: 5 * 1000
  86. })
  87. return Promise.reject(error)
  88. }
  89. )
  90. export default service