request.js 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. import * as config from '@/config'
  2. let baseUrl = config.def().baseUrlNew
  3. // 定义基础请求路径(后端服务器地址)
  4. const baseRequest = (method, url, data, header) => {
  5. var contentheader = 'application/json'
  6. if (header) {
  7. contentheader = header
  8. }
  9. let userInfo = uni.getStorageSync('userInfo');
  10. let baseDefaultOpts = {
  11. url: baseUrl + url,
  12. // 请求接口地址
  13. data: data,
  14. // 传入请求参数
  15. method: method,
  16. // 配置请求类型
  17. header: {
  18. 'content-type': contentheader ,//'application/x-www-form-urlencoded; charset=UTF-8',
  19. 'accessToken':userInfo.accessToken
  20. }
  21. }
  22. let promise = new Promise(function(resolve, reject) {
  23. uni.getNetworkType({}).then((res) => {
  24. console.log(res)
  25. if (res[1].networkType === "none") {
  26. uni.showToast({
  27. icon: 'none',
  28. title: '网络异常,请检查网络状况',
  29. duration: 2000
  30. });
  31. } else {
  32. uni.request(baseDefaultOpts).then(
  33. (res) => {
  34. if (res.cookies) {
  35. console.log(res.cookies)
  36. if (res.cookies.length != 0) {
  37. uni.setStorageSync('cookie', res.cookies[0]);
  38. }
  39. }
  40. // console.log(JSON.stringify(res[1].data))
  41. // if(res[1].data.code == '200' || res[1].data.code == 200){
  42. // // 后端返回的状态码100为成功状态,成功则返回请求结果,在app调试时可以通过console.log(JSON.stringify(res[1].data))来查看返回值(以项目实际情况为准)
  43. // resolve(res[1].data)
  44. // }else{
  45. // uni.showToast({
  46. // icon:'none',
  47. // title: res[1].data.message,
  48. // duration: 2000
  49. // });
  50. // }
  51. if (res[1]) {
  52. if (res[1].data.code == '200' || res[1].data.code == 200) {
  53. resolve(res[1].data)
  54. }else{
  55. resolve(res[1].data)
  56. // uni.$u.toast(res[1].data.message);
  57. // uni.showToast({
  58. // icon:'none',
  59. // title: res[1].data.message,
  60. // duration: 2000
  61. // });
  62. }
  63. } else {
  64. reject(res)
  65. // uni.showToast({
  66. // icon: 'none',
  67. // title: '网络异常,请检查网络状况',
  68. // duration: 2000
  69. // });
  70. }
  71. // // 登录失败
  72. // if(res[1].data.code == '11006' || res[1].data.code == 11006){
  73. // reject(res[1].data)
  74. // }
  75. // if(res[1].data.code == '105' || res[1].data.code == 105){
  76. // // 后端返回状态码为105则为未登录状态(以项目实际情况为准)
  77. // uni.showToast({
  78. // icon:'none',
  79. // title: '尚未登录',
  80. // duration: 2000
  81. // });
  82. // // 尚未登录的逻辑处理
  83. // return false
  84. // }
  85. }
  86. ).catch(
  87. (response) => {
  88. reject(response)
  89. }
  90. )
  91. }
  92. })
  93. })
  94. return promise
  95. };
  96. //带Token请求
  97. const TokenRequest = (method, url, data, header) => {
  98. var contentheader = 'application/json'
  99. if (header) {
  100. contentheader = header
  101. }
  102. let ac_token = "";
  103. uni.getStorage({
  104. key: 'userInfo',
  105. success: function(res) {
  106. ac_token = res.data.accessToken
  107. }
  108. });
  109. //此token是登录成功后后台返回保存在storage中的
  110. let DefaultOpts = {
  111. url: baseUrl + url,
  112. data: data,
  113. method: method,
  114. header: {
  115. 'content-type': contentheader,
  116. 'Token': ac_token,
  117. }
  118. }
  119. let promise = new Promise(function(resolve, reject) {
  120. uni.request(DefaultOpts).then(
  121. (res) => {
  122. console.log(JSON.stringify(res[1].data))
  123. if (res[1].data.code == '200' || res[1].data.code == 200) {
  124. // 后端返回的状态码100为成功状态,成功则返回请求结果,在app调试时可以通过console.log(JSON.stringify(res[1].data))来查看返回值(以项目实际情况为准)
  125. resolve(res[1].data)
  126. }
  127. if (res[1].data.code == '105' || res[1].data.code == 105) {
  128. // 后端返回状态码为105则为未登录状态(以项目实际情况为准)
  129. uni.showToast({
  130. icon: 'none',
  131. title: '尚未登录',
  132. duration: 2000
  133. });
  134. // 尚未登录的逻辑处理
  135. return false
  136. }
  137. }
  138. ).catch(
  139. (response) => {
  140. reject(response)
  141. }
  142. )
  143. })
  144. return promise
  145. }
  146. export default {
  147. baseUrl,
  148. baseRequest,
  149. TokenRequest
  150. }