request.js 3.7 KB

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