axios.config.js 4.0 KB

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