request.js 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  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. }
  47. } else {
  48. reject(response)
  49. // uni.showToast({
  50. // icon: 'none',
  51. // title: '网络异常,请检查网络状况',
  52. // duration: 2000
  53. // });
  54. }
  55. // // 登录失败
  56. // if(res[1].data.code == '11006' || res[1].data.code == 11006){
  57. // reject(res[1].data)
  58. // }
  59. // if(res[1].data.code == '105' || res[1].data.code == 105){
  60. // // 后端返回状态码为105则为未登录状态(以项目实际情况为准)
  61. // uni.showToast({
  62. // icon:'none',
  63. // title: '尚未登录',
  64. // duration: 2000
  65. // });
  66. // // 尚未登录的逻辑处理
  67. // return false
  68. // }
  69. }
  70. ).catch(
  71. (response) => {
  72. reject(response)
  73. }
  74. )
  75. }
  76. })
  77. })
  78. return promise
  79. };
  80. //带Token请求
  81. const TokenRequest = (method, url, data, header) => {
  82. var contentheader = 'application/json'
  83. if (header) {
  84. contentheader = header
  85. }
  86. let ac_token = "";
  87. uni.getStorage({
  88. key: 'userInfo',
  89. success: function(res) {
  90. ac_token = res.data.accessToken
  91. }
  92. });
  93. //此token是登录成功后后台返回保存在storage中的
  94. let DefaultOpts = {
  95. url: baseUrl + url,
  96. data: data,
  97. method: method,
  98. header: {
  99. 'content-type': contentheader,
  100. 'Token': ac_token,
  101. }
  102. }
  103. let promise = new Promise(function(resolve, reject) {
  104. uni.request(DefaultOpts).then(
  105. (res) => {
  106. console.log(JSON.stringify(res[1].data))
  107. if (res[1].data.code == '200' || res[1].data.code == 200) {
  108. // 后端返回的状态码100为成功状态,成功则返回请求结果,在app调试时可以通过console.log(JSON.stringify(res[1].data))来查看返回值(以项目实际情况为准)
  109. resolve(res[1].data)
  110. }
  111. if (res[1].data.code == '105' || res[1].data.code == 105) {
  112. // 后端返回状态码为105则为未登录状态(以项目实际情况为准)
  113. uni.showToast({
  114. icon: 'none',
  115. title: '尚未登录',
  116. duration: 2000
  117. });
  118. // 尚未登录的逻辑处理
  119. return false
  120. }
  121. }
  122. ).catch(
  123. (response) => {
  124. reject(response)
  125. }
  126. )
  127. })
  128. return promise
  129. }
  130. export default {
  131. baseUrl,
  132. baseRequest,
  133. TokenRequest
  134. }