axios.js 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. "use strict";
  2. /* eslint-disable */
  3. import axios from "axios"
  4. // import router from '../router/index'
  5. import { browser } from '@/common/common'
  6. // Full config: https://github.com/axios/axios#request-config
  7. // axios.defaults.baseURL = process.env.baseURL || process.env.apiUrl || '';
  8. // axios.defaults.headers.common['Authorization'] = AUTH_TOKEN;
  9. // axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded';
  10. let config = {
  11. // baseURL: process.env.baseURL || process.env.apiUrl || ""
  12. // timeout: 60 * 1000, // Timeout
  13. // withCredentials: true, // Check cross-site Access-Control
  14. // transformRequest: [function(data) {
  15. // console.log(data)
  16. // if(!data.qStringify) {
  17. // data = qs.stringify({
  18. // ...data
  19. // })
  20. // }
  21. // return data
  22. // }]
  23. };
  24. const _axios = axios.create(config);
  25. _axios.interceptors.request.use(
  26. function (config) {
  27. // Do something before request is sent
  28. // 判断用户是否登录
  29. if (browser().android || browser().iPhone) { // app里面
  30. let userInfo = decodeURI(localStorage.getItem('Authorization'))
  31. if (userInfo) {
  32. config.headers['Authorization'] = userInfo
  33. }
  34. } else { // 网页里面
  35. let auth = decodeURI(localStorage.getItem('userInfo'))
  36. if (auth) {
  37. config.headers['Authorization'] = auth
  38. }
  39. }
  40. const tenantId = sessionStorage.getItem('tenantId')
  41. if(tenantId && tenantId != 'undefined') {
  42. config.headers['tenantId'] = tenantId
  43. }
  44. // config.headers['Authorization'] = 'bearer 5848d682-f5a3-4ce1-b86d-5b5f466ae665'
  45. return config;
  46. },
  47. function (error) {
  48. // Do something with request error
  49. return Promise.reject(error);
  50. }
  51. );
  52. // Add a response interceptor
  53. _axios.interceptors.response.use(
  54. function (response) {
  55. // Do something with response data
  56. if (response.data.code == 403) {
  57. window.localStorage.removeItem('userInfo') // 删除用户信息
  58. window.localStorage.removeItem('Authorization') // 删除用户信息
  59. // android ios 注册方法
  60. if (browser().android) {
  61. DAYA.postMessage(JSON.stringify({ api: 'login' }))
  62. } else if (browser().iPhone) {
  63. window.webkit.messageHandlers.DAYA.postMessage(JSON.stringify({ api: 'login' }))
  64. }
  65. }
  66. return response;
  67. },
  68. function (error) {
  69. // Do something with response error
  70. return Promise.reject(error);
  71. }
  72. );
  73. // Plugin.install = function(Vue) {
  74. // Vue.axios = _axios;
  75. // window.axios = _axios;
  76. // Object.defineProperties(Vue.prototype, {
  77. // axios: {
  78. // get() {
  79. // return _axios;
  80. // }
  81. // },
  82. // $axios: {
  83. // get() {
  84. // return _axios;
  85. // }
  86. // },
  87. // });
  88. // };
  89. // Vue.use(Plugin)
  90. export default _axios