request.js 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216
  1. // import {
  2. // refreshTokenFn
  3. // } from "@/api/services/login.js";
  4. import api from "@/config/api.js";
  5. import Request from "@/utils/lib/request/index.js";
  6. import Foundation from "@/utils/Foundation.js";
  7. import md5 from "@/utils/md5.js";
  8. import storage from "@/utils/storage.js";
  9. import jwt from '@/utils/js_sdk/t-jwt/jwt.js';
  10. import uuid from "@/utils/uuid.modified.js";
  11. import store from "../store";
  12. let isNavigateTo = false
  13. function cleanStorage() {
  14. uni.showToast({
  15. title: "你的登录状态已过期,请重新登录",
  16. icon: "none",
  17. duration: 1500,
  18. });
  19. if (uni.showLoading()) {
  20. uni.hideLoading();
  21. }
  22. storage.setHasLogin(false);
  23. storage.setAccessToken("");
  24. // storage.setRefreshToken("");
  25. storage.setUuid("");
  26. storage.setUserInfo({});
  27. /* if (!isNavigateTo) {
  28. isNavigateTo = true
  29. // 防抖处理跳转
  30. // #ifdef MP-WEIXIN
  31. uni.navigateTo({
  32. url: "/pages/login/index",
  33. });
  34. // #endif
  35. // #ifndef MP-WEIXIN
  36. uni.navigateTo({
  37. url: "/pages/passport/login",
  38. });
  39. // #endif
  40. } */
  41. }
  42. let http = new Request();
  43. /**
  44. * 创建uuid方法
  45. */
  46. const createUuid = () => {
  47. if (!storage.getUuid()) {
  48. storage.setUuid(uuid.v4());
  49. console.log("uuid", storage.getUuid());
  50. }
  51. }
  52. http.setConfig((config) => {
  53. createUuid();
  54. /* 设置全局配置 */
  55. config.baseURL = api.serve;
  56. config.header = {
  57. ...config.header,
  58. };
  59. config.validateStatus = (statusCode) => {
  60. // 不论什么状态,统一在正确中处理
  61. return true;
  62. };
  63. return config;
  64. });
  65. http.interceptors.request.use(
  66. (config) => {
  67. /* 请求之前拦截器。可以使用async await 做异步操作 */
  68. let accessToken = storage.getAccessToken();
  69. if(storage.getInviter()){
  70. config.header.inviter = storage.getInviter();
  71. }
  72. console.log("请求前处理");
  73. if (accessToken) {
  74. /**
  75. * 使用JWT解析
  76. * 小于当前时间将当前token清除
  77. */
  78. const decodeJwt = jwt(accessToken);
  79. const timing = new Date().getTime() / 1000
  80. if (decodeJwt.exp <= timing) {
  81. accessToken = ""
  82. storage.setAccessToken('')
  83. }
  84. const nonce = Foundation.randomString(6);
  85. const timestamp = parseInt(new Date().getTime() / 1000);
  86. const sign = md5(nonce + timestamp + accessToken);
  87. const _params = {
  88. nonce,
  89. timestamp,
  90. sign,
  91. };
  92. let params = config.params || {};
  93. params = {
  94. ...params,
  95. ..._params
  96. };
  97. config.params = params;
  98. // config.header.accessToken = accessToken;
  99. config.header.Authorization = 'Bearer '+accessToken;
  100. }
  101. createUuid();
  102. config.header = {
  103. ...config.header,
  104. uuid: storage.getUuid()
  105. };
  106. return config;
  107. },
  108. (config) => {
  109. return Promise.reject(config);
  110. }
  111. );
  112. // 是否正在刷新的标记
  113. let isRefreshing = false;
  114. //重试队列
  115. let requests = [];
  116. // 必须使用异步函数,注意
  117. http.interceptors.response.use(
  118. async (response) => {
  119. isNavigateTo = false;
  120. uni.showLoading() ? uni.hideLoading() : '';
  121. let token = storage.getAccessToken();
  122. console.log("请求后的处理",response);
  123. // token存在但401,说明过期了
  124. if ((token && response.statusCode === 401) || response.data.status === 401) {
  125. console.log('token过期或无效,跳转登录', token);
  126. cleanStorage(); // 清理缓存中的token、用户信息等
  127. uni.showToast({
  128. title: '登录已过期,请重新登录',
  129. icon: 'none',
  130. duration: 2000,
  131. complete: () => {
  132. setTimeout(() => {
  133. uni.navigateTo({
  134. url: '/pages/login/index'
  135. }); // 跳转登录页
  136. }, 2000);
  137. }
  138. });
  139. return Promise.reject('登录状态过期');
  140. }
  141. // 未登录也跳转
  142. if ((!token && !storage.getAccessToken() && response.statusCode === 401) || response.data.code === 401) {
  143. console.log('无token,跳转登录');
  144. cleanStorage();
  145. uni.showToast({
  146. title: '请先登录',
  147. icon: 'none',
  148. duration: 2000,
  149. complete: () => {
  150. setTimeout(() => {
  151. uni.navigateTo({
  152. url: '/pages/login/index'
  153. });
  154. }, 2000);
  155. }
  156. });
  157. return Promise.reject('未登录');
  158. }
  159. // 请求成功但业务失败
  160. if (
  161. (response.statusCode === 200 && !response.data.success) ||
  162. response.statusCode === 400
  163. ) {
  164. if (response.data.message) {
  165. uni.showToast({
  166. title: response.data.message,
  167. icon: "none",
  168. duration: 1500,
  169. success: () => { store.state.isShowToast = true; },
  170. fail: () => { store.state.isShowToast = false; },
  171. complete: () => { store.state.isShowToast = false; }
  172. });
  173. }
  174. }
  175. return response;
  176. },
  177. (error) => {
  178. return Promise.reject(error);
  179. }
  180. );
  181. export {
  182. http
  183. };
  184. export const Method = {
  185. GET: "GET",
  186. POST: "POST",
  187. PUT: "PUT",
  188. DELETE: "DELETE",
  189. };