interceptor.ts 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. import Taro from '@tarojs/taro';
  2. import api from './server/index';
  3. import { setApp } from './config';
  4. import appInfoStore from '@src/store/appInfo'
  5. import bookStore from '@src/store/book'
  6. import { getRechargeTemplate } from './server/index/index';
  7. export interface ResData {
  8. code: number,
  9. data: any,
  10. fail: boolean,
  11. msg: string,
  12. success: boolean
  13. }
  14. //拦截器
  15. let isOpne = false //弹窗是否开启
  16. // 因没有权限等待的请求
  17. let pendingRequests: any[] = [];
  18. // 请求拦截器
  19. const requestInterceptor = (chain) => {
  20. // 展示loding弹窗逻辑
  21. if (app.isLoding && !isOpne) {
  22. isOpne = true
  23. Taro.showLoading({ title: "加载中..." })
  24. }
  25. const requestParams = chain.requestParams;
  26. requestParams.url = requestParams.url?.match(/^http[s]?:\/\//ig) ? requestParams.url : app.apiUrl + requestParams.url
  27. // 是登录接口token换成inittoken
  28. let token = requestParams.url.match(/(\/jsCodeLogin)|(\/appComponent\/list)/ig) ? app.initToken : app.token
  29. // 不存在token并且不是init和login接口关闭请求
  30. if (!token && !requestParams.url.match(/(\/jsCodeLogin)|(\/loginInitialize)/ig)) {
  31. // 打印日志或执行一些清理操作
  32. console.log("Token 无效,取消请求,并存入待请求列表,授权后重新请求");
  33. // 存入待请求列表
  34. pendingRequests.push(chain);
  35. // 返回一个被拒绝的Promise以中断请求
  36. return new Promise(() => { });
  37. }
  38. // 处理参数
  39. // if (requestParams.data?.workDirection) {
  40. // if (requestParams.data?.workDirection === "男生") {
  41. // requestParams.data.workDirection = 0
  42. // } else {
  43. // requestParams.data.workDirection = 1
  44. // }
  45. // }
  46. //分类列表假如上次请求的频道没变就不再获取
  47. if (requestParams.url.includes('/app/bookCategory/list')) {
  48. if (requestParams.data.workDirection === bookStore.oldWorkDirection) {
  49. log("阻止参数不变获取分类")
  50. return new Promise(() => { });
  51. } else {
  52. //赋值本次的请求
  53. bookStore.setData({ oldWorkDirection: requestParams.data.workDirection })
  54. }
  55. }
  56. requestParams.header = {
  57. ...requestParams.header,
  58. "Token": token
  59. }
  60. // 继续请求
  61. return chain.proceed(requestParams);
  62. };
  63. // 响应拦截器
  64. const responseInterceptor = (chain) => {
  65. return chain.proceed(chain.requestParams).then(async (response) => {
  66. const { data } = response;
  67. let { code } = data
  68. // 在这里处理返回的数据
  69. switch (code) {
  70. case 200:
  71. // 初始化接口调用登录接口,登录接口存在自己的执行判断
  72. if (chain.requestParams.url.includes("loginInitialize")) {
  73. setApp({ initToken: data.data.token })
  74. appInfoStore.actionAppInfo(data.data.appInfo)
  75. let user: any = await api.login()
  76. Taro.setStorageSync("userInfo", user)
  77. let temp: any = await getRechargeTemplate()
  78. console.log("temp", temp)
  79. setApp({ appName: data?.data?.appInfo?.appName })
  80. appInfoStore.setData({ appInfo: data.data.appInfo, })
  81. // 检测待请求列表中是否存在请求,存在就执行请求
  82. while (pendingRequests.length > 0) {
  83. console.log("存在待请求")
  84. const pendingChain = pendingRequests.shift();
  85. Taro.request(pendingChain.requestParams);
  86. }
  87. }
  88. break;
  89. case 300:
  90. log("token过期,重新登录", data)
  91. setApp({ token: "" })
  92. await api.loginInit(app.appId)
  93. // 重新执行当前请求
  94. console.log("登录后重新请求===>")
  95. const newRequestParams = chain.requestParams;
  96. return Taro.request(newRequestParams).then(newResponse => newResponse.data);
  97. default:
  98. log("未知错误", data)
  99. Taro.showToast({
  100. title: data.msg,
  101. icon: 'error',
  102. duration: 1000
  103. })
  104. break;
  105. }
  106. //关闭login弹窗
  107. if (isOpne) {
  108. isOpne = false
  109. Taro.hideLoading()
  110. }
  111. return data;
  112. });
  113. };
  114. // 添加请求拦截器
  115. Taro.addInterceptor(requestInterceptor);
  116. // 添加响应拦截器
  117. Taro.addInterceptor(responseInterceptor);