request_assess.ts 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. import axios from 'axios';
  2. import { ElMessage, ElMessageBox } from 'element-plus';
  3. import { Session } from '/@/utils/storage';
  4. // 配置新建一个 axios 实例
  5. const service = axios.create({
  6. baseURL: import.meta.env.VITE_ASSESS_URL,
  7. timeout: 50000,
  8. headers: { 'Content-Type': 'application/json' },
  9. });
  10. // 添加请求拦截器
  11. service.interceptors.request.use(
  12. (config) => {
  13. // 在发送请求之前做些什么 token
  14. if (Session.get('token')) {
  15. // (<any>config.headers).common['Authorization'] = `Bearer ${Session.get('token')}`;
  16. }
  17. return config;
  18. },
  19. (error) => {
  20. // 对请求错误做些什么
  21. return Promise.reject(error);
  22. }
  23. );
  24. // 添加响应拦截器
  25. service.interceptors.response.use(
  26. (response) => {
  27. // 对响应数据做点什么
  28. const res = response.data;
  29. const code = response.data.code
  30. if (code === 401) {
  31. ElMessageBox.alert('登录状态已过期,请重新登录', '提示', { confirmButtonText: '确定' })
  32. .then(() => {
  33. Session.clear(); // 清除浏览器全部临时缓存
  34. window.location.href = '/'; // 去登录页
  35. })
  36. .catch(() => { });
  37. } else if (code !== 0) {
  38. ElMessage.error(res.message)
  39. return Promise.reject(new Error(res.message))
  40. } else {
  41. // 分页的数据
  42. if (res.data?.Total !== undefined) {
  43. return {
  44. list: res.data.Data,
  45. total: res.data.Total,
  46. page: res.data.currentPage,
  47. ...res.data,
  48. }
  49. }
  50. if (res.data?.Data) {
  51. return res.data.Data
  52. }
  53. if (res.data?.Data === undefined) {
  54. return res.data
  55. }
  56. }
  57. },
  58. (error) => {
  59. // 对响应错误做点什么
  60. if (error.message.indexOf('timeout') != -1) {
  61. ElMessage.error('网络超时');
  62. } else if (error.message == 'Network Error') {
  63. ElMessage.error('网络连接错误');
  64. } else {
  65. if (error.response.data) ElMessage.error(error.response.statusText);
  66. else ElMessage.error('接口路径找不到');
  67. }
  68. return Promise.reject(error);
  69. }
  70. );
  71. // 导出 axios 实例
  72. export default service;
  73. export function get(url: string, params?: any): any {
  74. return service({
  75. url,
  76. method: "get",
  77. params
  78. })
  79. }
  80. export function post(url: string, data?: any): any {
  81. return service({
  82. url,
  83. method: "post",
  84. data
  85. })
  86. }
  87. export function put(url: string, data?: any): any {
  88. return service({
  89. url,
  90. method: "put",
  91. data
  92. })
  93. }
  94. export function del(url: string, data?: any): any{
  95. return service({
  96. url,
  97. method: "delete",
  98. data
  99. })
  100. }