axios.config.js 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. import axios from "axios"
  2. import qs from "qs"
  3. // axios.defaults.timeout = 180000 //响应时间
  4. axios.defaults.timeout = 600000 //响应时间
  5. axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded;charset=UTF-8'; //配置请求头
  6. axios.defaults.baseURL = process.env.NODE_HOST; //配置接口地址
  7. console.log(process.env)
  8. const CancelToken = axios.CancelToken;
  9. let cancel; // 用于存储取消请求的方法
  10. //POST传参序列化(添加请求拦截器)
  11. axios.interceptors.request.use((config) => {
  12. //在发送请求之前做某件事
  13. let token = sessionStorage.getItem('access_token') || "" //获取token
  14. if (token != "") {
  15. config.headers = {
  16. 'access-token': token,
  17. 'Content-Type': 'application/x-www-form-urlencoded'
  18. }
  19. }
  20. // if (config.data && config.data[0].post == '1' && config.method === 'post') {
  21. // // config.headers.post['Content-Type'] = 'application/json;charset=UTF-8';
  22. // // config.data = config.data//序列化post 参数
  23. // config.data = 'mode=' + (Object.values(config.data[0]).join(','))//序列化post 参数
  24. // } else if (config.method === 'post') {
  25. // config.data = qs.stringify(config.data)//序列化post 参数
  26. // }
  27. if (config.url === 'https://gpt.cocorobo.cn/search_image' || config.url === 'https://gpt.cocorobo.cn/chat' || config.url === 'https://gpt4.cocorobo.cn/create_free_assistants' || config.url === 'https://gpt4.cocorobo.cn/assistants_completion_response') {
  28. config.data = config.data//序列化post 参数
  29. } else if (config.url.indexOf('https://r2rserver.cocorobo.cn') != -1) {
  30. config.headers = {
  31. 'Content-Type': 'application/json',
  32. }
  33. } else if (config.url.indexOf('https://gpt4.cocorobo.cn/') != -1 || config.url.indexOf('https://claude3.cocorobo.cn/') != -1 || config.url.indexOf('llm.cocorobo.cn/') != -1 || config.url.indexOf('https://appapi.cocorobo.cn/')!=-1) {
  34. config.headers = {
  35. 'Content-Type': 'application/json',
  36. }
  37. } else if (config.data && config.data[0].post == '1' && config.method === 'post') {
  38. config.data = 'mode=' + (Object.values(config.data[0]).join(','))//序列化post 参数
  39. } else if (config.method === 'post') {
  40. const encoded = {};
  41. for (const key in config.data[0]) {
  42. if (Object.hasOwnProperty.call(config.data[0], key)) {
  43. encoded[key] = encodeURIComponent(config.data[0][key]);
  44. }
  45. }
  46. config.data = qs.stringify([encoded]) //序列化post 参数
  47. } else {
  48. const encoded = {};
  49. for (const key in config.data) {
  50. if (Object.hasOwnProperty.call(config.data, key)) {
  51. encoded[key] = encodeURIComponent(config.data[key]);
  52. }
  53. }
  54. config.data = encoded
  55. }
  56. return config;
  57. }, (error) => {
  58. console.log('错误的传参')
  59. return Promise.reject(error);
  60. });
  61. //返回状态判断(添加响应拦截器)
  62. axios.interceptors.response.use((res) => {
  63. //对响应数据做些事
  64. if (!res.data.success) {
  65. let newToken = res.data.token //成功后更新token
  66. localStorage.setItem('access_token', newToken)
  67. }
  68. return res;
  69. }, (error) => {
  70. if (axios.isCancel(error)) {
  71. console.log('请求已取消', error.message);
  72. } else if (error.response.data.status == '401') { //如果token 过期 则跳转到登录页面
  73. this.$router.push('/login');
  74. }
  75. return Promise.reject(error);
  76. });
  77. //返回一个Promise(发送post请求)
  78. function post(url, params, source) {
  79. return new Promise((resolve, reject) => {
  80. axios.post(url, params, source ? { cancelToken: source.token } : '')
  81. .then(response => {
  82. resolve(response);
  83. }, err => {
  84. reject(err);
  85. })
  86. .catch((error) => {
  87. reject(error)
  88. })
  89. })
  90. }
  91. //返回一个Promise(发送put请求)
  92. function put(url, params, source) {
  93. return new Promise((resolve, reject) => {
  94. axios.put(url, params, source ? { cancelToken: source.token } : '')
  95. .then(response => {
  96. resolve(response);
  97. }, err => {
  98. reject(err);
  99. })
  100. .catch((error) => {
  101. reject(error)
  102. })
  103. })
  104. }
  105. ////返回一个Promise(发送get请求)
  106. function get(url, param, source) {
  107. return new Promise((resolve, reject) => {
  108. let cancelToken = source ? source.token : ''
  109. axios.get(url, { params: param, cancelToken })
  110. .then(response => {
  111. resolve(response)
  112. }, err => {
  113. reject(err)
  114. })
  115. .catch((error) => {
  116. reject(error)
  117. })
  118. })
  119. }
  120. export default {
  121. get,
  122. post,
  123. put,
  124. setCancelSource: () => {
  125. // 每次创建新的请求时,可以调用此方法以创建新的取消令牌
  126. cancel = CancelToken.source();
  127. return cancel;
  128. }
  129. }