request.ts 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. import axios from 'axios';
  2. import { ElMessage, ElMessageBox } from 'element-plus';
  3. import getOrigin from '/@/utils/origin'
  4. import { getToken, removeToken } from "/@/utils/auth";
  5. // 配置新建一个 axios 实例
  6. const service = axios.create({
  7. baseURL: getOrigin(),
  8. timeout: 120000,
  9. headers: { 'Content-Type': 'application/json' },
  10. });
  11. // 添加请求拦截器
  12. service.interceptors.request.use(
  13. (config) => {
  14. // 在发送请求之前做些什么 token
  15. if (getToken()) {
  16. (<any>config.headers).common['Authorization'] = `Bearer ${getToken()}`;
  17. }
  18. return config;
  19. },
  20. (error) => {
  21. // 对请求错误做些什么
  22. return Promise.reject(error);
  23. }
  24. );
  25. // 添加响应拦截器
  26. service.interceptors.response.use(
  27. (response) => {
  28. // 对响应数据做点什么
  29. const res = response.data;
  30. const code = response.data.code
  31. if (code === 401) {
  32. ElMessageBox.alert('登录状态已过期,请重新登录', '提示',
  33. { confirmButtonText: '确定', showCancelButton: false, closeOnHashChange: false, closeOnPressEscape: false, closeOnClickModal: false, showClose: false })
  34. .then(() => {
  35. localStorage.clear(); // 清除缓存/token等
  36. sessionStorage.clear(); // 清除缓存/token等
  37. removeToken()
  38. window.location.href = '/'; // 去登录页
  39. })
  40. } else if (code === undefined && res.message === undefined) { // 可能是下载文件
  41. return response
  42. } else if (code !== 0) {
  43. ElMessage.closeAll()
  44. ElMessage.error(res.message)
  45. return Promise.reject(new Error(res.message))
  46. } else {
  47. // 分页的数据
  48. if (res.data?.Total !== undefined) {
  49. return {
  50. list: res.data.Data,
  51. total: res.data.Total,
  52. page: res.data.currentPage,
  53. ...res.data,
  54. }
  55. }
  56. // if (res.data?.Data) {
  57. // return res.data.Data
  58. // }
  59. if (res.data?.Info && res.data?.Data) { // currentUser接口
  60. return res.data
  61. }
  62. if (res.data?.Data === undefined) {
  63. return res.data
  64. }
  65. // 兼容环路监测页面的Report字段
  66. if (res.data?.Report !== undefined) {
  67. return res.data
  68. }
  69. return res.data.Data
  70. }
  71. },
  72. (error) => {
  73. ElMessage.closeAll()
  74. // 对响应错误做点什么
  75. if (error.message.indexOf('timeout') != -1) {
  76. ElMessage.error('网络超时');
  77. } else if (error.message == 'Network Error') {
  78. ElMessage.error('网络连接错误');
  79. } else {
  80. if (error.response.data) ElMessage.error(error.response.statusText);
  81. else ElMessage.error('接口路径找不到');
  82. }
  83. return Promise.reject(error);
  84. }
  85. );
  86. // 导出 axios 实例
  87. export default service;
  88. export function get(url: string, params?: any): any {
  89. return service({
  90. url,
  91. method: "get",
  92. params
  93. })
  94. }
  95. export function post(url: string, data?: any): any {
  96. return service({
  97. url,
  98. method: "post",
  99. data
  100. })
  101. }
  102. export function put(url: string, data?: any): any {
  103. return service({
  104. url,
  105. method: "put",
  106. data
  107. })
  108. }
  109. export function del(url: string, data?: any): any {
  110. return service({
  111. url,
  112. method: "delete",
  113. data
  114. })
  115. }
  116. export function file(url: string, params?: any, method: 'get' | 'post' = 'get'): any {
  117. if (method === 'get') {
  118. return service({
  119. url,
  120. method,
  121. params,
  122. timeout: 120000,
  123. responseType: 'arraybuffer',
  124. });
  125. } else {
  126. return service({
  127. url,
  128. method,
  129. timeout: 120000,
  130. data: params,
  131. responseType: 'blob',
  132. });
  133. }
  134. }