newRequest.js 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247
  1. import store from '../store';
  2. import {
  3. getUpimgKey
  4. } from '@/api/login.js';
  5. let service = {
  6. baseURL: store.state.baseURL, // 请求头
  7. header: {
  8. 'Content-Type': "application/x-www-form-urlencoded"
  9. },
  10. // 请求拦截器
  11. interceptors: {
  12. // 安装请求前拦截
  13. request: function(success, iserror) {
  14. service.request.success = success;
  15. service.request.error = iserror;
  16. },
  17. // 安装请求完成后拦截
  18. response: function(success, iserror) {
  19. service.response.success = success;
  20. service.response.error = iserror;
  21. }
  22. },
  23. // 请求前拦截
  24. request: {
  25. // 回调成功执行方法
  26. success: function(e) {
  27. return e
  28. },
  29. // 回调失败
  30. error: function(e) {
  31. return e
  32. }
  33. },
  34. // 请求完成后拦截
  35. response: {
  36. // 回调成功执行方法
  37. success: function(e) {
  38. return e
  39. },
  40. // 回调失败
  41. error: function(e) {
  42. return e
  43. }
  44. },
  45. // 开始请求
  46. open: async function(data) {
  47. return await new Promise(function(resolve, reject) {
  48. let requestData = ''; //保存处理完成后请求数据
  49. let url = '' //保存链接地址
  50. //console.log(data);
  51. // 请求前数据处理
  52. requestData = service.request.success(data);
  53. // #ifdef H5
  54. if (process.env.NODE_ENV === 'development') {
  55. url = requestData.url;
  56. console.log('开发环境')
  57. } else {
  58. url = service.baseURL + requestData.url;
  59. console.log('生产环境')
  60. }
  61. // #endif
  62. // #ifndef H5
  63. url = service.baseURL + requestData.url;
  64. // #endif
  65. console.log(url, '请求地址信息');
  66. // 数据复制用于请求
  67. uni.request({
  68. url: url,
  69. method: requestData.method || 'GET',
  70. data: requestData.data,
  71. header: data.header || service.header,
  72. success: res => {
  73. if (res.statusCode == 200) {
  74. try {
  75. resolve(service.response.success(res));
  76. } catch (e) {
  77. service.response.error(e)
  78. }
  79. }
  80. },
  81. // 请求失败数据处理
  82. fail: (err) => {
  83. service.response.error(err)
  84. }
  85. });
  86. })
  87. },
  88. // 上传文件
  89. upFilse: async function(data) {
  90. return await new Promise(async function(resolve, reject) {
  91. let requestData = ''; //保存处理完成后请求数据
  92. let url = '' //保存请求地址
  93. try {
  94. // 请求前数据处理
  95. requestData = service.request.success(data);
  96. } catch (e) {
  97. // 请求报错拦截
  98. service.request.error(e);
  99. }
  100. // #ifdef H5
  101. if (process.env.NODE_ENV === 'development') {
  102. url = requestData.url;
  103. console.log('开发环境')
  104. } else {
  105. url = service.baseURL + requestData.url;
  106. console.log('生产环境')
  107. }
  108. // #endif
  109. // #ifndef H5
  110. url = service.baseURL + requestData.url;
  111. // #endif
  112. let config = {
  113. // 上传图片的API
  114. upload_img_url: url,
  115. data: requestData.data,
  116. file_name: requestData.data.file_name || 'user/' + store.state.user.userInfo.uid
  117. }
  118. uni.showLoading({
  119. title: '请求key中',
  120. mark: true,
  121. })
  122. try {
  123. const {
  124. data
  125. } = await getUpimgKey({
  126. file_name: config.file_name
  127. })
  128. uni.hideLoading()
  129. setTimeout(()=>{
  130. uni.chooseImage({
  131. count: 1,
  132. sizeType: ['compressed'],
  133. sourceType: ['camera', 'album'],
  134. success(res) {
  135. uni.showLoading({
  136. title: '上传中',
  137. mark: true,
  138. })
  139. try{
  140. // console.log(res, '选中图片');
  141. const time = (new Date()).getTime();
  142. // #ifdef H5
  143. const formData = {
  144. "policy": data.sign.policy,
  145. "OSSAccessKeyId": data.sign.accessid,
  146. 'success_action_status': 200,
  147. "signature": data.sign.signature,
  148. "key": config.file_name + '/' + time + res.tempFiles[0]
  149. .name
  150. }
  151. // #endif
  152. // #ifndef H5
  153. const formData = {
  154. "policy": data.sign.policy,
  155. "OSSAccessKeyId": data.sign.accessid,
  156. 'success_action_status': 200,
  157. "signature": data.sign.signature,
  158. "key": config.file_name + '/' + time + '.png'
  159. }
  160. // #endif
  161. // console.log(formData,'formData');
  162. uni.uploadFile({
  163. url: data.sign.host, //仅为示例,非真实的接口地址
  164. filePath: res.tempFilePaths[0],
  165. formData,
  166. name: 'file',
  167. header: {
  168. "Authori-zation": 'Bearer ' + uni
  169. .getStorageSync('token')
  170. },
  171. success: (suc) => {
  172. if (suc.statusCode == 200) {
  173. // #ifdef H5
  174. const imgurl = [{
  175. url: data.sign.host + '/' +
  176. config.file_name + '/' +
  177. time + res.tempFiles[0]
  178. .name
  179. }];
  180. // #endif
  181. // #ifndef H5
  182. const imgurl = [{
  183. url: data.sign.host + '/' +
  184. config.file_name + '/' +
  185. time + '.png'
  186. }];
  187. // #endif
  188. resolve(imgurl)
  189. }
  190. uni.hideLoading()
  191. },
  192. file(res) {
  193. uni.hideLoading()
  194. // console.log(res, '图片上传错误');
  195. reject(res)
  196. }
  197. });
  198. }catch(e){
  199. uni.showModal({
  200. title: '错误',
  201. content: e.message,
  202. showCancel: false
  203. });
  204. }
  205. },
  206. fail(err) {
  207. if (err.errCode == 0) {
  208. uni.showToast({
  209. title: '已取消',
  210. icon: "error"
  211. });
  212. } else if (err.errCode == 12) {
  213. uni.showToast({
  214. title: '已返回',
  215. icon: "error"
  216. });
  217. } else {
  218. console.log(err, '图片上传错误');
  219. uni.showToast({
  220. title: '请重新上传',
  221. icon: "error"
  222. });
  223. }
  224. uni.hideLoading()
  225. reject(err)
  226. }
  227. })
  228. })
  229. } catch (e) {
  230. uni.hideLoading()
  231. uni.showToast({
  232. title: e.message,
  233. icon: "error"
  234. });
  235. reject(res)
  236. }
  237. })
  238. },
  239. };
  240. export default service