request.js 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. /**
  2. * axios 实例
  3. */
  4. import axios from 'axios';
  5. import router from '@/router';
  6. import { MessageBox, Message } from 'element-ui';
  7. import { API_BASE_URL, TOKEN_HEADER_NAME, LAYOUT_PATH } from '@/config/setting';
  8. import { getToken, setToken } from './token-util';
  9. import { logout } from './page-tab-util';
  10. import JSONBIG from 'json-bigint';
  11. const service = axios.create({
  12. baseURL: API_BASE_URL,
  13. transformResponse: [
  14. function (data) {
  15. if (data instanceof Blob) {
  16. return data;
  17. }
  18. const json = JSONBIG({
  19. storeAsString: true
  20. });
  21. const res = json.parse(data);
  22. return res;
  23. }
  24. ]
  25. });
  26. /**
  27. * 添加请求拦截器
  28. */
  29. service.interceptors.request.use(
  30. (config) => {
  31. // 添加 token 到 header
  32. const token = getToken();
  33. if (token && config.headers) {
  34. config.headers.common[TOKEN_HEADER_NAME] = token;
  35. }
  36. return config;
  37. },
  38. (error) => {
  39. return Promise.reject(error);
  40. }
  41. );
  42. /**
  43. * 添加响应拦截器
  44. */
  45. service.interceptors.response.use(
  46. (res) => {
  47. // token 自动续期
  48. console.log(res);
  49. // && res.config?.showErrorToast !== false
  50. if (Number(res.data.code) == -1) {
  51. // Message.error({
  52. // dangerouslyUseHTMLString: true,
  53. // message:res.data.message}
  54. // );
  55. return res;
  56. }
  57. if (Number(res.data.code) == 500 ) {
  58. Message.error({
  59. dangerouslyUseHTMLString: true,
  60. message:res.data.message}
  61. );
  62. return res;
  63. }
  64. const token = res.headers[TOKEN_HEADER_NAME.toLowerCase()];
  65. if (token) {
  66. setToken(token);
  67. }
  68. return res;
  69. },
  70. (error) => {
  71. // 登录过期处理
  72. if (error?.response?.status === 401) {
  73. const currentPath = router.currentRoute.path;
  74. if (currentPath === LAYOUT_PATH) {
  75. logout(true);
  76. } else {
  77. MessageBox.alert('登录状态已过期, 请退出重新登录!', '系统提示', {
  78. confirmButtonText: '重新登录',
  79. callback: (action) => {
  80. if (action === 'confirm') {
  81. logout(false, currentPath);
  82. }
  83. },
  84. beforeClose: () => {
  85. MessageBox.close();
  86. }
  87. });
  88. }
  89. return Promise.reject(new Error(error.response.data?.message));
  90. }
  91. return Promise.reject(error);
  92. }
  93. );
  94. export default service;