newRequest.js 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213
  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(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. })
  121. getUpimgKey({
  122. file_name: config.file_name
  123. }).then(({
  124. data
  125. }) => {
  126. uni.hideLoading()
  127. uni.chooseImage({
  128. count: 1,
  129. sourceType: ['camera', 'album'],
  130. success(res) {
  131. uni.showLoading({
  132. title: '上传中'
  133. })
  134. // console.log(res, '选中图片');
  135. const time = (new Date()).getTime();
  136. // #ifdef H5
  137. const formData = {
  138. "policy": data.sign.policy,
  139. "OSSAccessKeyId": data.sign.accessid,
  140. 'success_action_status': 200,
  141. "signature": data.sign.signature,
  142. "key": config.file_name+'/'+time+res.tempFiles[0].name
  143. }
  144. // #endif
  145. // #ifndef H5
  146. const formData = {
  147. "policy": data.sign.policy,
  148. "OSSAccessKeyId": data.sign.accessid,
  149. 'success_action_status': 200,
  150. "signature": data.sign.signature,
  151. "key": config.file_name+'/'+time+'.png'
  152. }
  153. // #endif
  154. // console.log(formData,'formData');
  155. uni.uploadFile({
  156. url: data.sign.host, //仅为示例,非真实的接口地址
  157. filePath: res.tempFilePaths[0],
  158. formData,
  159. name: 'file',
  160. header: {
  161. "Authori-zation": 'Bearer ' + uni
  162. .getStorageSync('token')
  163. },
  164. success: (suc) => {
  165. if(suc.statusCode==200){
  166. // #ifdef H5
  167. const imgurl = [{url:data.sign.host+'/'+config.file_name+'/'+time+res.tempFiles[0].name}];
  168. // #endif
  169. // #ifndef H5
  170. const imgurl = [{url:data.sign.host+'/'+config.file_name+'/'+time+'.png'}];
  171. // #endif
  172. resolve(imgurl)
  173. }
  174. uni.hideLoading()
  175. },
  176. file(res) {
  177. uni.hideLoading()
  178. // console.log(res, '图片上传错误');
  179. reject(res)
  180. }
  181. });
  182. },
  183. complete() {
  184. uni.hideLoading()
  185. },
  186. fail(err) {
  187. // console.log(res, '图片上传错误');
  188. uni.showToast({
  189. title: '图片上传失败',
  190. icon:"error"
  191. });
  192. uni.hideLoading()
  193. reject(err)
  194. }
  195. })
  196. }).catch((res)=>{
  197. uni.hideLoading()
  198. uni.showToast({
  199. title: 'key请求失败',
  200. icon:"error"
  201. });
  202. reject(res)
  203. })
  204. })
  205. },
  206. };
  207. export default service