request.js 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. import axios from 'axios'
  2. import router from "@/router";
  3. // 创建可一个新的axios对象
  4. const request = axios.create({
  5. baseURL: process.env.VUE_APP_BASEURL, // 后端的接口地址 ip:port
  6. timeout: 30000 // 30s请求超时
  7. })
  8. // request 拦截器
  9. // 可以自请求发送前对请求做一些处理
  10. // 比如统一加token,对请求参数统一加密
  11. request.interceptors.request.use(config => {
  12. config.headers['Content-Type'] = 'application/json;charset=utf-8'; // 设置请求头格式
  13. let user = JSON.parse(localStorage.getItem("xm-user") || '{}') // 获取缓存的用户信息
  14. config.headers['token'] = user.token // 设置请求头
  15. return config
  16. }, error => {
  17. console.error('request error: ' + error) // for debug
  18. return Promise.reject(error)
  19. });
  20. // response 拦截器
  21. // 可以在接口响应后统一处理结果
  22. request.interceptors.response.use(
  23. response => {
  24. let res = response.data;
  25. // 兼容服务端返回的字符串数据
  26. if (typeof res === 'string') {
  27. res = res ? JSON.parse(res) : res
  28. }
  29. if (res.code === '401') {
  30. router.push('/login')
  31. }
  32. return res;
  33. },
  34. error => {
  35. console.error('response error: ' + error) // for debug
  36. return Promise.reject(error)
  37. }
  38. )
  39. export default request