service.js 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. import Request from "@/common/luch-request/index.js";
  2. import { ACCESS_TOKEN } from "@/common/util/constants.js";
  3. import configService from "./config.service.js";
  4. import tip from "@/common/util/tip.js";
  5. import store from "@/store/index.js";
  6. let apiUrl = configService.apiUrl;
  7. const getTokenStorage = () => {
  8. let token = "";
  9. try {
  10. token = uni.getStorageSync(ACCESS_TOKEN);
  11. } catch (e) {
  12. //TODO handle the exception
  13. console.log("getTokenStorage", token);
  14. }
  15. return token;
  16. };
  17. const http = new Request();
  18. http.setConfig((config) => {
  19. /* 设置全局配置 */
  20. config.baseUrl = apiUrl; /* 根域名不同 */
  21. config.header = {
  22. ...config.header,
  23. };
  24. return config;
  25. });
  26. /**
  27. * 自定义验证器,如果返回true 则进入响应拦截器的响应成功函数(resolve),否则进入响应拦截器的响应错误函数(reject)
  28. * @param { Number } statusCode - 请求响应体statusCode(只读)
  29. * @return { Boolean } 如果为true,则 resolve, 否则 reject
  30. */
  31. // 有默认,非必写
  32. http.validateStatus = (statusCode) => {
  33. return statusCode === 200;
  34. };
  35. http.interceptor.request((config, cancel) => {
  36. /* 请求之前拦截器 */
  37. console.log(config, "config---");
  38. config.baseUrl = "";
  39. config.url = uni.getStorageSync("apiUrl") + config.url;
  40. config.header = {
  41. ...config.header,
  42. "X-Access-Token": getTokenStorage(),
  43. };
  44. /*
  45. if (!token) { // 如果token不存在,调用cancel 会取消本次请求,但是该函数的catch() 仍会执行
  46. cancel('token 不存在') // 接收一个参数,会传给catch((err) => {}) err.errMsg === 'token 不存在'
  47. }
  48. */
  49. return config;
  50. });
  51. // 必须使用异步函数,注意
  52. var that = this;
  53. http.interceptor.response(
  54. async (response) => {
  55. /* 请求之后拦截器 */
  56. // if (response.data.code !== 200) { // 服务端返回的状态码不等于200,则reject()
  57. // return Promise.reject(response)
  58. // }
  59. return response;
  60. },
  61. (response) => {
  62. // 请求错误做点什么
  63. console.log("请求错误做点什么", response);
  64. if (response) {
  65. let data = response.data;
  66. const token = uni.getStorageSync(ACCESS_TOKEN);
  67. console.log("------异常响应------", token);
  68. console.log("------异常响应------", data.code);
  69. switch (data.code) {
  70. case 403:
  71. tip.error("拒绝访问");
  72. break;
  73. case 500:
  74. if (!token || data.message == "Token失效,请重新登录") {
  75. let timeout = setTimeout(tip.alert("登录已过期"), 1000);
  76. store.dispatch("Logout").then(() => {
  77. clearTimeout(timeout);
  78. window.location.reload();
  79. });
  80. }
  81. break;
  82. case 404:
  83. break;
  84. case 504:
  85. break;
  86. case 401:
  87. console.log("------异常响应-401-----", 401);
  88. console.log("------uni-----", uni);
  89. uni.navigateTo({
  90. url: "/pages/login/login",
  91. });
  92. return;
  93. if (token) {
  94. /* store.dispatch('Logout').then(() => {
  95. setTimeout(() => {
  96. window.location.reload()
  97. }, 1500)
  98. }) */
  99. }
  100. break;
  101. default:
  102. tip.error({
  103. duration: 0,
  104. forbidClick: true,
  105. message: data.message,
  106. });
  107. break;
  108. }
  109. }
  110. return response;
  111. }
  112. );
  113. export { http };