api.js 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. import {
  2. clientId,
  3. clientSecret
  4. } from '@/common/setting'
  5. import {
  6. options
  7. } from '@/http/config.js';
  8. import {
  9. Base64
  10. } from '@/utils/base64.js';
  11. import Request from '@/utils/luch-request/index.js';
  12. const http = new Request(options);
  13. const checkNetworkStatus = () => {
  14. return new Promise((resolve, reject) => {
  15. uni.getNetworkType({
  16. success: (res) => {
  17. console.log(res)
  18. if (res.networkType === 'none') {
  19. reject(new Error('网络连接已断开'));
  20. } else {
  21. resolve(true);
  22. }
  23. },
  24. fail: () => {
  25. reject(new Error('网络状态检测失败'));
  26. }
  27. });
  28. });
  29. };
  30. http.interceptors.request.use(async (config) => { // 可使用async await 做异步操作
  31. try {
  32. await checkNetworkStatus();
  33. } catch (error) {
  34. uni.showToast({
  35. title: error.message,
  36. icon: 'none',
  37. duration: 3000
  38. });
  39. return Promise.reject(config);
  40. }
  41. // 假设有token值需要在头部需要携带
  42. let accessToken = uni.getStorageSync('accessToken');
  43. if (accessToken) {
  44. config.header['Blade-Auth'] = 'bearer ' + accessToken;
  45. } else {
  46. config.header['tenant-id'] = uni.getStorageSync('tenantId')
  47. }
  48. // 客户端认证参数
  49. config.header['Authorization'] = 'Basic ' + Base64.encode(clientId + ':' + clientSecret);
  50. // 额外参数
  51. // config.data = config.data || {};
  52. // config.data.pf = uni.getSystemInfoSync().platform;
  53. // config.data.sys = uni.getSystemInfoSync().system;
  54. // 演示custom 用处
  55. // if (config.custom.auth) {
  56. // config.header.token = 'token'
  57. // }
  58. // if (config.custom.loading) {
  59. // uni.showLoading()
  60. // }
  61. /**
  62. /* 演示
  63. if (!token) { // 如果token不存在,return Promise.reject(config) 会取消本次请求
  64. return Promise.reject(config)
  65. }
  66. **/
  67. return config
  68. }, config => { // 可使用async await 做异步操作
  69. return Promise.reject(config)
  70. })
  71. http.interceptors.response.use((response) => {
  72. // 若有数据返回则通过
  73. if (response.data.access_token || response.data.key) {
  74. return response.data
  75. }
  76. // 服务端返回的状态码不等于200,则reject()
  77. if (response.data.code !== 200) {
  78. if (response.data.code === 400) {
  79. uni.showToast({
  80. title: response.data.msg,
  81. icon: 'none'
  82. });
  83. } else if (response.data.code) {
  84. return Promise.reject(response);
  85. } else {
  86. return response.data;
  87. }
  88. }
  89. return response.data;
  90. }, (response) => {
  91. if (response.statusCode === 0 || !response.statusCode) {
  92. uni.showToast({
  93. title: '网络连接中断,请检查网络设置',
  94. icon: 'none',
  95. duration: 3000
  96. });
  97. return Promise.reject(response);
  98. }
  99. /* 对响应错误做点什么 (statusCode !== 200)*/
  100. if (response.data.code === 401) {
  101. uni.showModal({
  102. title: '提示',
  103. content: '登录状态失效,点击确定重新登录',
  104. showCancel: false,
  105. success: function(res) {
  106. if (res.confirm) {
  107. uni.reLaunch({
  108. url: '/pages/login/index'
  109. });
  110. }
  111. }
  112. });
  113. } else if (response.data.error === "unauthorized") {
  114. if (response.data.error_description) {
  115. uni.showToast({
  116. title: response.data.error_description,
  117. icon: 'none'
  118. });
  119. } else {
  120. uni.showToast({
  121. title: response.data.error,
  122. icon: 'none'
  123. });
  124. }
  125. } else if (response.data.error == "invalid_grant") {
  126. uni.showToast({
  127. title: response.data.error_description,
  128. icon: 'none'
  129. });
  130. } else if (response.data.error == "access_denied") {
  131. uni.showToast({
  132. title: response.data.error_description,
  133. icon: 'none'
  134. });
  135. } else {
  136. uni.showToast({
  137. title: response.data.msg,
  138. icon: 'none'
  139. });
  140. }
  141. return Promise.reject(response.data)
  142. })
  143. export default http;