axios.config.js 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. import axios from "axios"
  2. import qs from "qs"
  3. axios.defaults.timeout = 3000 //响应时间
  4. axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded;charset=UTF-8'; //配置请求头
  5. axios.defaults.baseURL = process.env.NODE_HOST; //配置接口地址
  6. console.log(process.env)
  7. //POST传参序列化(添加请求拦截器)
  8. axios.interceptors.request.use((config) => {
  9. //在发送请求之前做某件事
  10. let token = sessionStorage.getItem('access_token') || "" //获取token
  11. console.log(token)
  12. if (token != "") {
  13. config.headers = {
  14. 'access-token': token,
  15. 'Content-Type': 'application/x-www-form-urlencoded'
  16. }
  17. }
  18. // if (config.data && config.data[0].post == '1' && config.method === 'post') {
  19. // // config.headers.post['Content-Type'] = 'application/json;charset=UTF-8';
  20. // // config.data = config.data//序列化post 参数
  21. // config.data = 'mode=' + (Object.values(config.data[0]).join(','))//序列化post 参数
  22. // } else if (config.method === 'post') {
  23. // config.data = qs.stringify(config.data)//序列化post 参数
  24. // }
  25. if (config.data && config.data[0].post == '1' && config.method === 'post') {
  26. config.data = 'mode=' + (Object.values(config.data[0]).join(','))//序列化post 参数
  27. } else if(config.method === 'post') {
  28. config.data = qs.stringify(config.data)//序列化post 参数
  29. }
  30. return config;
  31. }, (error) => {
  32. console.log('错误的传参')
  33. return Promise.reject(error);
  34. });
  35. //返回状态判断(添加响应拦截器)
  36. axios.interceptors.response.use((res) => {
  37. //对响应数据做些事
  38. if (!res.data.success) {
  39. let newToken = res.data.token //成功后更新token
  40. localStorage.setItem('access_token', newToken)
  41. }
  42. return res;
  43. }, (error) => {
  44. if (error.response.data.status == '401') { //如果token 过期 则跳转到登录页面
  45. this.$router.push('/login');
  46. }
  47. return Promise.reject(error);
  48. });
  49. //返回一个Promise(发送post请求)
  50. function post(url, params) {
  51. return new Promise((resolve, reject) => {
  52. axios.post(url, params)
  53. .then(response => {
  54. resolve(response);
  55. }, err => {
  56. reject(err);
  57. })
  58. .catch((error) => {
  59. reject(error)
  60. })
  61. })
  62. }
  63. ////返回一个Promise(发送get请求)
  64. function get(url, param) {
  65. return new Promise((resolve, reject) => {
  66. axios.get(url, { params: param })
  67. .then(response => {
  68. resolve(response)
  69. }, err => {
  70. reject(err)
  71. })
  72. .catch((error) => {
  73. reject(error)
  74. })
  75. })
  76. }
  77. export default {
  78. get,
  79. post,
  80. }