newRequest.js 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199
  1. import store from '../store'
  2. let service = {
  3. baseURL: store.state.baseURL, // 请求头
  4. header: {
  5. 'Content-Type': "application/x-www-form-urlencoded"
  6. },
  7. // 请求拦截器
  8. interceptors: {
  9. // 安装请求前拦截
  10. request: function(success, iserror) {
  11. service.request.success = success;
  12. service.request.error = iserror;
  13. },
  14. // 安装请求完成后拦截
  15. response: function(success, iserror) {
  16. service.response.success = success;
  17. service.response.error = iserror;
  18. }
  19. },
  20. // 请求前拦截
  21. request: {
  22. // 回调成功执行方法
  23. success: function(e) {
  24. return e
  25. },
  26. // 回调失败
  27. error: function(e) {
  28. return e
  29. }
  30. },
  31. // 请求完成后拦截
  32. response: {
  33. // 回调成功执行方法
  34. success: function(e) {
  35. return e
  36. },
  37. // 回调失败
  38. error: function(e) {
  39. return e
  40. }
  41. },
  42. // 开始请求
  43. open: async function(data) {
  44. return await new Promise(function(resolve, reject) {
  45. let requestData = ''; //保存处理完成后请求数据
  46. let url = '' //保存链接地址
  47. //console.log(data);
  48. // 请求前数据处理
  49. requestData = service.request.success(data);
  50. // #ifdef H5
  51. if (process.env.NODE_ENV === 'development') {
  52. url ='/api'+ requestData.url;
  53. console.log(url,'url+++')
  54. console.log('开发环境')
  55. } else {
  56. url = service.baseURL + requestData.url;
  57. console.log('生产环境')
  58. }
  59. // #endif
  60. // #ifndef H5
  61. url = service.baseURL + requestData.url;
  62. // #endif
  63. // 数据复制用于请求
  64. uni.request({
  65. url: url,
  66. method: requestData.method || 'GET',
  67. data: requestData.data,
  68. header: data.header || service.header,
  69. success: res => {
  70. if (res.statusCode == 200) {
  71. try {
  72. resolve(service.response.success(res));
  73. } catch (e) {
  74. service.response.error(e)
  75. }
  76. }
  77. },
  78. // 请求失败数据处理
  79. fail: (err) => {
  80. service.response.error(err)
  81. }
  82. });
  83. })
  84. },
  85. // 上传文件
  86. upFilse: async function(data) {
  87. return await new Promise(function(resolve, reject) {
  88. let requestData = ''; //保存处理完成后请求数据
  89. let url = '' //保存请求地址
  90. try {
  91. // 请求前数据处理
  92. requestData = service.request.success(data);
  93. } catch (e) {
  94. // 请求报错拦截
  95. service.request.error(e);
  96. }
  97. // #ifdef H5
  98. if (process.env.NODE_ENV === 'development') {
  99. url = requestData.url;
  100. console.log('开发环境')
  101. } else {
  102. url = service.baseURL + requestData.url;
  103. console.log('生产环境')
  104. }
  105. // #endif
  106. // #ifndef H5
  107. url = service.baseURL + requestData.url;
  108. // #endif
  109. let config = {
  110. // 上传图片的API
  111. upload_img_url: url
  112. }
  113. let Uploader = {
  114. // 选择图片
  115. choose(num) {
  116. return new Promise((resolve, reject) => {
  117. uni.chooseImage({
  118. count: num,
  119. success(res) {
  120. // console.log(res);
  121. // 缓存文件路径
  122. resolve(res.tempFilePaths)
  123. },
  124. fail(err) {
  125. console.log(err)
  126. reject(err)
  127. }
  128. })
  129. })
  130. },
  131. // 上传图片
  132. upload_one(path) {
  133. return new Promise((resolve, reject) => {
  134. uni.showLoading({
  135. title: '上传中'
  136. })
  137. uni.uploadFile({
  138. url: config.upload_img_url, //仅为示例,非真实的接口地址
  139. filePath: path,
  140. name: 'file',
  141. header: {
  142. "Authori-zation": 'Bearer ' + uni.getStorageSync(
  143. 'token')
  144. },
  145. success: (uploadFileRes) => {
  146. console.log(uploadFileRes.data, "url");
  147. if ("string" === typeof uploadFileRes.data) {
  148. resolve(JSON.parse(uploadFileRes.data).data)
  149. } else {
  150. resolve(uploadFileRes.data.data)
  151. }
  152. },
  153. complete() {
  154. uni.hideLoading()
  155. }
  156. });
  157. })
  158. },
  159. // 上传多个图片
  160. upload(path_arr) {
  161. let num = path_arr.length;
  162. return new Promise(async (resolve, reject) => {
  163. let img_urls = []
  164. for (let i = 0; i < num; i++) {
  165. let img_url = await this.upload_one(path_arr[i]);
  166. img_urls.push(img_url)
  167. };
  168. resolve(img_urls)
  169. })
  170. },
  171. // 触发上传图片事件
  172. choose_and_upload(num) {
  173. return new Promise(async (resolve, reject) => {
  174. // 选择图片
  175. let path_arr = await this.choose(num);
  176. // 上传图片
  177. await this.upload(path_arr).then((e) => {
  178. resolve(e);
  179. }).catch((e) => {
  180. reject(e)
  181. });
  182. })
  183. }
  184. };
  185. Uploader.choose_and_upload(1).then((e) => {
  186. resolve(e);
  187. }).catch((e) => {
  188. console.log(e);
  189. })
  190. })
  191. },
  192. };
  193. export default service