axios-nuxt.js 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. import Vue from 'vue'
  2. import Axios from 'axios'
  3. const service = Axios.create({
  4. withCredentials: true,
  5. baseUrl: '/'
  6. })
  7. export function axiosHttp(store) {
  8. service.interceptors.request.use(config => {
  9. if (typeof window === 'undefined') {
  10. config.headers.cookie = store.state.option.cookies + '; ' + store.state.option.sessionId
  11. config.headers['User-Agent'] = Vue.$store.state.option.userAgent
  12. config.url = process.env.baseUrl + config.url
  13. } else {
  14. // console.log(store)
  15. }
  16. return config
  17. }, error => {
  18. return Promise.reject(error)
  19. })
  20. service.interceptors.response.use(response => {
  21. const cookies = response.headers['set-cookie']
  22. if (cookies && cookies.length) {
  23. for (let i = 0; i < cookies.length; i++) {
  24. if (cookies[i].indexOf('JSESSIONID') > -1) {
  25. const sessionId = cookies[i]
  26. const first = sessionId.indexOf(';')
  27. const second = sessionId.lastIndexOf(';')
  28. const newSessionId = sessionId.replace(sessionId.substring(first, second), '')
  29. store.commit('option/SET_SESSION_ID', newSessionId)
  30. break
  31. }
  32. }
  33. }
  34. return response
  35. }, error => {
  36. return Promise.reject(error)
  37. })
  38. Vue.prototype.$http = service
  39. return service
  40. }
  41. export default function ({ isServer, store, req }) {
  42. axiosHttp(store)
  43. }