llm-request.js 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. import axios from 'axios';
  2. import * as Storage from './storage';
  3. import { notification } from 'ant-design-vue';
  4. // const getBaseUrl = () => window.AppGlobalConfig.server;
  5. const getBaseUrl = () => '/llm';
  6. // 请求超时时间 60s
  7. axios.defaults.timeout = 60 * 1000;
  8. const request = axios.create({
  9. // API 请求的默认前缀
  10. baseURL: getBaseUrl(),
  11. });
  12. // 请求拦截器
  13. axios.interceptors.request.use(
  14. config => {
  15. // 每次发送请求之前判断是否存在token,如果存在,则统一在http请求的header都加上token,不用每次请求都手动添加了
  16. // 即使本地存在token,也有可能token是过期的,所以在响应拦截器中要对返回状态进行判断
  17. const token = Storage.getCache('Token');
  18. if (token) {
  19. config.headers.Authorization = token;
  20. }
  21. if(config.method.toUpperCase() === 'POST') {
  22. config.headers['Content-Type'] = 'application/json;charset=utf-8'
  23. }
  24. return config
  25. },
  26. error => {
  27. return Promise.error(error)
  28. })
  29. const errorHandler = (error) => {
  30. if (error.response) {
  31. const data = error.response.data;
  32. // 从 localstorage 获取 token
  33. // @ts-ignore
  34. // const token = userStore().accessToken;
  35. if (error.response.status === 403) {
  36. notification.error({
  37. message: 'Forbidden',
  38. description: data.message,
  39. });
  40. }
  41. if (error.response.status === 401 && !(data.result && data.result.isLogin)) {
  42. notification.error({
  43. message: 'Unauthorized',
  44. description: 'Authorization verification failed',
  45. });
  46. // if (token) {
  47. // userStore()
  48. // .loginOut()
  49. // .then(() => {
  50. // setTimeout(() => {
  51. // window.location.reload();
  52. // }, 1500);
  53. // });
  54. // }
  55. }
  56. if (error.code === 'ERR_NETWORK') {
  57. notification.error({
  58. message: '网络问题',
  59. description: error.message,
  60. });
  61. }
  62. }
  63. return Promise.reject(error);
  64. };
  65. request.interceptors.response.use(response => {
  66. if (response?.data?.code === 401) {
  67. notification.error({
  68. message: '用户验证失败',
  69. description: '用户信息失效,请重新登录',
  70. });
  71. // @ts-ignore
  72. // const token = userStore().accessToken;
  73. // if (token) {
  74. // userStore()
  75. // .loginOut()
  76. // .then(() => {
  77. // setTimeout(() => {
  78. // window.location.reload();
  79. // }, 1500);
  80. // });
  81. // }
  82. }
  83. return response.data;
  84. }, errorHandler);
  85. export default request;