axios.config.js 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  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.url.indexOf('https://dify.cocorobo.cn') != -1) {
  38. if (config.url.indexOf('?key=role') != -1) {
  39. config.headers = {
  40. Authorization: `Bearer app-TonzLPv7rPG0EtnFKszOWjwt`,
  41. "Content-Type": "application/json"
  42. }
  43. } else if (config.url.indexOf('?key=code') != -1) {
  44. config.headers = {
  45. Authorization: `Bearer app-zOMxBqyEKoJSvW10e5SS0kgj`,
  46. "Content-Type": "application/json"
  47. }
  48. }
  49. } else if (config.data && config.data[0].post == '1' && config.method === 'post') {
  50. config.data = 'mode=' + (Object.values(config.data[0]).join(','))//序列化post 参数
  51. } else if (config.method === 'post') {
  52. const encoded = {};
  53. for (const key in config.data[0]) {
  54. if (Object.hasOwnProperty.call(config.data[0], key)) {
  55. encoded[key] = encodeURIComponent(config.data[0][key]);
  56. }
  57. }
  58. config.data = qs.stringify([encoded]) //序列化post 参数
  59. } else {
  60. const encoded = {};
  61. for (const key in config.data) {
  62. if (Object.hasOwnProperty.call(config.data, key)) {
  63. encoded[key] = encodeURIComponent(config.data[key]);
  64. }
  65. }
  66. config.data = encoded
  67. }
  68. return config;
  69. }, (error) => {
  70. console.log('错误的传参')
  71. return Promise.reject(error);
  72. });
  73. //返回状态判断(添加响应拦截器)
  74. axios.interceptors.response.use((res) => {
  75. //对响应数据做些事
  76. if (!res.data.success) {
  77. let newToken = res.data.token //成功后更新token
  78. localStorage.setItem('access_token', newToken)
  79. }
  80. return res;
  81. }, (error) => {
  82. if (axios.isCancel(error)) {
  83. console.log('请求已取消', error.message);
  84. } else if (error.response.data.status == '401') { //如果token 过期 则跳转到登录页面
  85. this.$router.push('/login');
  86. }
  87. return Promise.reject(error);
  88. });
  89. //返回一个Promise(发送post请求)
  90. function post(url, params, source) {
  91. return new Promise((resolve, reject) => {
  92. axios.post(url, params, source ? { cancelToken: source.token } : '')
  93. .then(response => {
  94. resolve(response);
  95. }, err => {
  96. reject(err);
  97. })
  98. .catch((error) => {
  99. reject(error)
  100. })
  101. })
  102. }
  103. //返回一个Promise(发送put请求)
  104. function put(url, params, source) {
  105. return new Promise((resolve, reject) => {
  106. axios.put(url, params, source ? { cancelToken: source.token } : '')
  107. .then(response => {
  108. resolve(response);
  109. }, err => {
  110. reject(err);
  111. })
  112. .catch((error) => {
  113. reject(error)
  114. })
  115. })
  116. }
  117. ////返回一个Promise(发送get请求)
  118. function get(url, param, source) {
  119. return new Promise((resolve, reject) => {
  120. let cancelToken = source ? source.token : ''
  121. axios.get(url, { params: param, cancelToken })
  122. .then(response => {
  123. resolve(response)
  124. }, err => {
  125. reject(err)
  126. })
  127. .catch((error) => {
  128. reject(error)
  129. })
  130. })
  131. }
  132. export default {
  133. get,
  134. post,
  135. put,
  136. setCancelSource: () => {
  137. // 每次创建新的请求时,可以调用此方法以创建新的取消令牌
  138. cancel = CancelToken.source();
  139. return cancel;
  140. }
  141. }