http.js 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209
  1. import axios from 'axios';
  2. import qs from 'qs';
  3. import Vue from 'vue';
  4. import config from '@/config';
  5. // 获取CancelToken
  6. const CancelToken = axios.CancelToken;
  7. const source = CancelToken.source();
  8. var http = axios.create({
  9. timout: 30000
  10. });
  11. // axios request 拦截器
  12. http.interceptors.request.use(
  13. (config) => {
  14. if (config.url.indexOf('/sc-user-auth') !== -1) {
  15. config.url = config.url;
  16. } else if (config.url.indexOf('/sc-message') !== -1) {
  17. config.url = config.url;
  18. } else if (config.url.indexOf('/operation-manager') !== -1) {
  19. config.url = config.url;
  20. } else if (config.url.indexOf('/zoniot-water') !== -1) {
  21. config.url = config.url;
  22. } else if (config.url.indexOf('/sc-user-center') !== -1) {
  23. config.url = config.url;
  24. } else if (config.url.indexOf('/sc-community') !== -1) {
  25. config.url = config.url;
  26. } else if (config.url.indexOf('/sc-charge') !== -1) {
  27. config.url = config.url;
  28. }
  29. // else {
  30. // config.url = `/sc-community${config.url}`;
  31. // }
  32. // config.headers['Accept'] = '*/*'
  33. config.headers[localStorage.getItem('SC_token') && 'Authorization'] = 'Bearer ' + localStorage.getItem('SC_token');
  34. // 全局添加cancelToken
  35. config.cancelToken = source.token;
  36. return config;
  37. },
  38. (err) => {
  39. return Promise.reject(err);
  40. }
  41. );
  42. // axios响应拦截
  43. http.interceptors.response.use(
  44. (res) => {
  45. return Promise.resolve(res.data);
  46. },
  47. (err) => {
  48. if (err.response.status == 401) {
  49. axios({
  50. url: '/user-auth/user/getUserStatus?accessToken=' + localStorage.getItem('SC_token'),
  51. method: 'get'
  52. }).then((response) => {
  53. if (window.relogin) return false;
  54. window.relogin = true;
  55. let data = response.data.data;
  56. if (data == 0) {
  57. Vue.prototype
  58. .$msgBox('你的登录已超时,请重新登录', '', 'warning', {
  59. width: '290px',
  60. showCancelButton: false,
  61. confirmButtonText: '确定',
  62. showClose: false
  63. })
  64. .then(() => {
  65. window.open(config.loginUrl, '_self');
  66. window.relogin = false;
  67. localStorage.removeItem('SC_token');
  68. })
  69. .catch(() => {});
  70. } else if (data == 1) {
  71. Vue.prototype
  72. .$msgBox('该账号已在其他地址登录,如需访问请重新登录', '', 'warning', {
  73. width: '290px',
  74. showCancelButton: false,
  75. confirmButtonText: '确定',
  76. showClose: false
  77. })
  78. .then(() => {
  79. window.open(config.loginUrl, '_self');
  80. window.relogin = false;
  81. localStorage.removeItem('SC_token');
  82. })
  83. .catch(() => {});
  84. } else {
  85. Vue.prototype
  86. .$msgBox('你的账号已被停用,如有问题请联系管理员', '', 'warning', {
  87. width: '290px',
  88. showCancelButton: false,
  89. confirmButtonText: '确定',
  90. showClose: false
  91. })
  92. .then(() => {
  93. window.open(config.loginUrl, '_self');
  94. window.relogin = false;
  95. localStorage.removeItem('SC_token');
  96. })
  97. .catch(() => {});
  98. }
  99. });
  100. return;
  101. }
  102. if (axios.isCancel(err)) return new Promise(() => {}); // 取消请求的情况下,终端Promise调用链
  103. return Promise.reject(err);
  104. }
  105. );
  106. export default {
  107. vm: '',
  108. post(url, data) {
  109. return new Promise((resolve, reject) => {
  110. http.post(url, data)
  111. .then((res) => {
  112. this.callback(resolve, res);
  113. })
  114. .catch((err) => {
  115. this.reject(reject, err);
  116. });
  117. });
  118. },
  119. postForm(url, data) {
  120. return new Promise((resolve, reject) => {
  121. http.post(url, qs.stringify(data))
  122. .then((res) => {
  123. this.callback(resolve, res);
  124. })
  125. .catch((err) => {
  126. this.reject(reject, err);
  127. });
  128. });
  129. },
  130. get(url, data) {
  131. for (let item in data) {
  132. if (data[item] && 'string' == typeof data[item]) {
  133. data[item] = data[item].replace(/[`!@#$%^&*()\[\]\\{}=\'\"\/<>]/g, '');
  134. }
  135. }
  136. return new Promise((resolve, reject) => {
  137. http.get(url, {
  138. params: data
  139. })
  140. .then((res) => {
  141. this.callback(resolve, res);
  142. })
  143. .catch((err) => {
  144. this.reject(reject, err);
  145. });
  146. });
  147. },
  148. delete(url, data) {
  149. return new Promise((resolve, reject) => {
  150. http.delete(url, {
  151. params: data
  152. })
  153. .then((res) => {
  154. this.callback(resolve, res);
  155. })
  156. .catch((err) => {
  157. this.reject(reject, err);
  158. });
  159. });
  160. },
  161. deleteJSON(url, data) {
  162. return new Promise((resolve, reject) => {
  163. http.delete(url, {
  164. data: data
  165. })
  166. .then((res) => {
  167. this.callback(resolve, res);
  168. })
  169. .catch((err) => {
  170. this.reject(reject, err);
  171. });
  172. });
  173. },
  174. putForm(url, data) {
  175. return new Promise((resolve, reject) => {
  176. http.put(url, qs.stringify(data))
  177. .then((res) => {
  178. this.callback(resolve, res);
  179. })
  180. .catch((err) => {
  181. this.reject(reject, err);
  182. });
  183. });
  184. },
  185. put(url, data) {
  186. return new Promise((resolve, reject) => {
  187. http.put(url, data)
  188. .then((res) => {
  189. this.callback(resolve, res);
  190. })
  191. .catch((err) => {
  192. this.reject(reject, err);
  193. });
  194. });
  195. },
  196. callback(resolve, res) {
  197. resolve(res);
  198. },
  199. reject(reject, err) {
  200. if (err instanceof Error) {
  201. ELEMENT.Message.error(err.message);
  202. }
  203. reject(err);
  204. }
  205. };