康巴易测肤/伤疤uniapp小程序类
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

146 lines
4.1KB

  1. import request from "./core/request.js"
  2. import {
  3. getToken,
  4. removeToken
  5. } from "@/utils/auth.js"
  6. // TODO: 设置基础接口地址,可根据小程序体验版和线上版本区分
  7. let baseUrl = "http://127.0.0.1";
  8. //可以new多个request来支持多个域名请求
  9. let $http = new request({
  10. //接口请求地址
  11. baseUrl: baseUrl,
  12. //设置请求头(如果使用报错跨域问题,可能是content-type请求类型和后台那边设置的不一致)
  13. header: {
  14. 'content-type': 'application/json;charset=UTF-8'
  15. },
  16. // 请求超时时间(默认6000)
  17. timeout: 10000,
  18. // 默认配置(可不写)
  19. config: {
  20. // 是否自动提示错误
  21. isPrompt: true,
  22. // 是否显示加载动画
  23. load: true,
  24. // 是否使用数据工厂
  25. isFactory: true
  26. }
  27. });
  28. //当前接口请求数
  29. let requestNum = 0;
  30. // 当前失败接口数
  31. let requestFailNum = 0;
  32. //请求开始拦截器
  33. $http.requestStart = function(options) {
  34. if (options.load) {
  35. if (requestNum <= 0) {
  36. //打开加载动画
  37. uni.showLoading({
  38. title: '加载中',
  39. mask: true
  40. });
  41. }
  42. requestNum += 1;
  43. }
  44. //请求前加入token,从缓存中读取token,请在登录后将token存储在本地缓存中
  45. options.header['token'] = getToken();
  46. return options;
  47. }
  48. //请求结束
  49. $http.requestEnd = function(options) {
  50. //判断当前接口是否需要加载动画
  51. if (options.load) {
  52. requestNum = requestNum - 1;
  53. if (requestNum <= 0) {
  54. uni.hideLoading();
  55. }
  56. }
  57. }
  58. //所有接口数据处理(可在接口里设置不调用此方法)
  59. //此方法需要开发者根据各自的接口返回类型修改,以下只是模板
  60. $http.dataFactory = async function(res) {
  61. if (res.response.statusCode && res.response.statusCode == 200) {
  62. let httpData = res.response.data;
  63. if (typeof(httpData) == "string") {
  64. httpData = JSON.parse(httpData);
  65. }
  66. /*********以下只是模板(及共参考),需要开发者根据各自的接口返回类型修改*********/
  67. // TODO: 判断数据是否请求成功,根据后端返回的成功状态码修改
  68. if (httpData.code == 200) {
  69. // 返回正确的结果(then接受数据)
  70. return Promise.resolve(httpData);
  71. } else { //其他错误提示
  72. if (res.isPrompt) {
  73. // 自动提示错误
  74. uni.showToast({
  75. title: httpData.info || httpData.msg,
  76. icon: "none",
  77. duration: 3000
  78. });
  79. }
  80. // 返回错误的结果(catch接受数据)
  81. return Promise.reject({
  82. statusCode: 500,
  83. errMsg: httpData.info || httpData.msg
  84. });
  85. }
  86. /*********以上只是模板(及共参考),需要开发者根据各自的接口返回类型修改*********/
  87. } else if (res.response.statusCode && res.response.statusCode == 401) {
  88. // 用户身份信息过期处理,清除token并返回登录页
  89. if(requestFailNum <= 0) {
  90. removeToken();
  91. uni.showModal({
  92. title: '温馨提示',
  93. content: '登录状态过期,请重新登录!',
  94. confirmText: "确认",
  95. showCancel: false,
  96. success: function(result) {
  97. uni.reLaunch({
  98. url: '/pages/login/index'
  99. });
  100. }
  101. });
  102. }
  103. requestFailNum++;
  104. return Promise.reject({
  105. statusCode: res.response.statusCode,
  106. errMsg: "登录状态过期"
  107. });
  108. } else if (res.response.statusCode && res.response.statusCode == 404) {
  109. // 接口地址不存在
  110. return Promise.reject({
  111. statusCode: res.response.statusCode,
  112. errMsg: "请求失败,请检查接口地址是否正确"
  113. });
  114. } else {
  115. // 返回错误的结果(catch接受数据)
  116. return Promise.reject({
  117. statusCode: res.response.statusCode,
  118. errMsg: "数据工厂验证不通过"
  119. });
  120. }
  121. };
  122. // 错误回调
  123. $http.requestError = function(e) {
  124. if(!e.errMsg) {
  125. return;
  126. }
  127. // e.statusCode === 0 是参数校验错误抛出的
  128. if (e.statusCode === 0 || e.statusCode === 401) {
  129. throw e;
  130. } else {
  131. // 解决hideLoading会隐藏Toast的bug,setTimeout让showToast在requestEnd回调之后再执行
  132. setTimeout(() => {
  133. if(e.errMsg == "request:fail") {
  134. e.errMsg = "请求失败,请检查接口地址是否正确!"
  135. }
  136. uni.showToast({
  137. title: e.errMsg || "网络错误,请检查一下网络",
  138. icon: "none",
  139. duration: 3000
  140. });
  141. })
  142. }
  143. }
  144. export default $http;