request.js 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. import axios from 'axios'
  2. import router from '../router/index'
  3. import { Toast } from 'vant';
  4. const wx = window.wx;
  5. import store from '../store/index';
  6. axios.defaults.withCredentials = false;
  7. axios.defaults.headers.common['token'] = store.state.home.token || window.localStorage.getItem("token");
  8. axios.defaults.headers.post['Content-Type'] = 'application/json;charset=UTF-8';//配置请求头
  9. // http request拦截器 添加一个请求拦截器
  10. axios.interceptors.request.use(function (config) {
  11. let token = store.state.home.token || window.localStorage.getItem("token")
  12. console.log(config, "config");
  13. if (token) {
  14. //将token放到请求头发送给服务器,将tokenkey放在请求头中
  15. config.headers.token = token;
  16. //也可以这种写法
  17. // config.headers['token'] = token;
  18. }
  19. return config;
  20. }, function (error) {
  21. Toast.fail('请求超时');
  22. // Do something with request error
  23. return Promise.reject(error);
  24. });
  25. // 添加一个响应拦截器
  26. axios.interceptors.response.use(function (response) {
  27. if (response.data && response.data.code) {
  28. if (response.data.code == 5001 || response.data.code == 5002 || response.data.msg === 'redis token is null') {
  29. //未登录
  30. Toast.fail("登录信息已失效,请重新登录");
  31. setTimeout(() => {
  32. wx.miniProgram.navigateTo({
  33. url: '/pages/home/index'
  34. })
  35. }, 500)
  36. }
  37. if (parseInt(response.data.code) === -1) {
  38. Toast.fail(response.data.msg);
  39. return Promise.reject(response.data);
  40. // Toast.fail("请求失败");
  41. }
  42. }
  43. return response;
  44. }, function (error) {
  45. Toast.fail("服务器连接失败");
  46. return Promise.reject(error);
  47. })
  48. let base = 'https://sit-nanhuacs.4dage.com/';
  49. //通用方法
  50. export const POST = (url, params, config) => {
  51. const getTimestamp = new Date().getTime();
  52. return axios.post(`${base}${url}?timer=${getTimestamp}`, params, config).then(res => res.data)
  53. }
  54. export const GET = (url, params) => {
  55. const getTimestamp = new Date().getTime();
  56. return axios.get(`${base}${url}?timer=${getTimestamp}`, { params: params }).then(res => res.data)
  57. }
  58. export const PUT = (url, params) => {
  59. return axios.put(`${base}${url}`, params).then(res => res.data)
  60. }
  61. export const DELETE = (url, params) => {
  62. return axios.delete(`${base}${url}`, { params: params }).then(res => res.data)
  63. }
  64. export const PATCH = (url, params) => {
  65. return axios.patch(`${base}${url}`, params).then(res => res.data)
  66. }