request.js 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292
  1. const app = getApp();
  2. // download.zhiqiyun.com 域名
  3. const env = {
  4. NODE_ENV: 'pota',
  5. dev: {
  6. apiUrl: 'https://unwx.e-chinalife.com'
  7. },
  8. prd: {
  9. apiUrl: 'https://apimall.zhiqiyun.com',
  10. },
  11. pota: {
  12. apiUrl: 'http://192.168.110.180:8098' ,//wjg
  13. // apiUrl: 'http://10.17.56.92:8098' ,//人寿内网
  14. }
  15. }
  16. var header = {
  17. 'content-type': 'application/x-www-form-urlencoded',
  18. /*--商户的appi通过参数传入--*/
  19. 'appId': '',
  20. // 'appId': 'ZQesLvuSYEejOJB', //测试
  21. // 'appId': 'ZQWYx7XoOOhv4Ns', //正式
  22. /*----*/
  23. }
  24. /**小程序配置 */
  25. const publics = {
  26. picUrls: 'https://zhiqiyun.oss-cn-hangzhou.aliyuncs.com/static/', //图片地址
  27. 'mapLBSKEY': 'XTABZ-5K3RW-MZVRD-3ZS33-GC5RE-YOBEG',
  28. }
  29. /*
  30. * 获取token
  31. */
  32. const getToken = (success) => {
  33. let token = getStorage('AUTH_TOKEN');
  34. if (token) {
  35. success.call(this, token);
  36. return false;
  37. } else {
  38. loadToken(data => {
  39. success.call(this, data);
  40. });
  41. }
  42. }
  43. const loadToken = (success) => {
  44. let that = this
  45. uni.request({
  46. url: env[env.NODE_ENV].apiUrl + '/api/access_token',
  47. data: {},
  48. method: 'get',
  49. header: header,
  50. success(json) {
  51. if (json.statusCode !== 200) return msg(json.data.message);
  52. if (json.data.code !== 0) return msg(json.data.msg)
  53. setStorage('AUTH_TOKEN', json.data.data);
  54. success.call(that, json.data.data);
  55. },
  56. fail() {
  57. msg('access_token 获取失败');
  58. }
  59. })
  60. }
  61. const clearValueEmpty = (data) => {
  62. let keyValue = {};
  63. for (let key in data) {
  64. let value = typeof data[key];
  65. if (value == 'string' && value) {
  66. if (data[key] != 'undefined' && data[key] != " " && data[key] != undefined && data[key] != null) {
  67. keyValue[key] = data[key];
  68. }
  69. } else if (value == 'number' && value != null) {
  70. keyValue[key] = data[key];
  71. } else if (value == 'boolean') {
  72. keyValue[key] = data[key];
  73. } else {
  74. if (data[key]) keyValue[key] = data[key];
  75. }
  76. }
  77. return keyValue;
  78. }
  79. /**
  80. * 公共请求
  81. *
  82. * @param {*} url 请求url
  83. * @param {*} data 请求参数
  84. * @param {*} method 请求方法
  85. * @param {*} success 成功函数
  86. * @param {*} isLoad 是否显示加载提示
  87. */
  88. const baseRequest = (url, data, method, success, isLoad) => {
  89. getToken(token => {
  90. if (isLoad) {
  91. load('加载中')
  92. }
  93. header.authorityToken = token;
  94. // if (url.indexOf('/v3') != -1 || url.indexOf('/paper/create') != -1) {
  95. // header['content-type'] = 'application/json;charset=UTF-8'
  96. // } else {
  97. // header['content-type'] = 'application/x-www-form-urlencoded'
  98. // }
  99. header['content-type'] = 'application/json;charset=UTF-8'
  100. try {
  101. var device_info = {};
  102. //第三放巨量投放渠道标记
  103. var pickleChannel = getStorage('pickleChannel');
  104. device_info.pickleChannel = pickleChannel;
  105. var packageChannel = getStorage('packageChannel');
  106. device_info.packageChannel = packageChannel;
  107. var deviceinfoString = JSON.stringify(device_info);
  108. deviceinfoString = deviceinfoString.replace(/{/g, '').replace(/}/g, '').replace(/:/g, '=')
  109. .replace(
  110. /,/g,
  111. ';').replace(/"/g,
  112. '');
  113. header['device-info'] = deviceinfoString;
  114. } catch (e) {}
  115. console.log('H5请求url===>',env[env.NODE_ENV].apiUrl + url,'请求方式 '+method)
  116. console.log('H5请求data===>',clearValueEmpty(data))
  117. uni.request({
  118. url: env[env.NODE_ENV].apiUrl + url,
  119. data: clearValueEmpty(data),
  120. method: method,
  121. header: header,
  122. success(json) {
  123. if (isLoad) {
  124. uni.hideLoading();
  125. }
  126. if (json.statusCode !== 200) return msg(json.data.message);
  127. if (json.data.code !== 0) {
  128. return msg(json.data.msg)
  129. }
  130. let data = json.data.data;
  131. if (typeof data === 'string' && data.indexOf("{") === 0) {
  132. data = JSON.parse(data);
  133. }
  134. console.log('H5请求返回===>',data)
  135. success.call(this, data);
  136. },
  137. fail() {
  138. if (isLoad) {
  139. uni.hideLoading();
  140. }
  141. },
  142. })
  143. })
  144. }
  145. const loadIng = (msg) => {
  146. uni.showLoading({
  147. title: msg,
  148. mask: true
  149. })
  150. }
  151. /**POST请求 */
  152. const postRequest = (url, data, success, isLoad) => {
  153. header['content-type'] = 'application/x-www-form-urlencoded'
  154. baseRequest(url, data, 'post', success, isLoad);
  155. }
  156. const postRequestLoding = (url, data, success, isLoding) => {
  157. header['content-type'] = 'application/x-www-form-urlencoded'
  158. baseRequest(url, data, 'post', success, false, isLoding);
  159. }
  160. /**GET请求 */
  161. const getRequest = (url, data, success, isLoad) => {
  162. header['content-type'] = 'application/x-www-form-urlencoded'
  163. baseRequest(url, data, 'get', success, isLoad);
  164. }
  165. /**Put请求 */
  166. const putRequest = (url, data, success, isLoad) => {
  167. header['content-type'] = 'application/x-www-form-urlencoded'
  168. baseRequest(url, data, 'put', success, isLoad)
  169. }
  170. const putRequestJson = (url, data, success, isLoad) => {
  171. header['content-type'] = 'application/json;charset=UTF-8'
  172. baseRequest(url, data, 'put', success, isLoad)
  173. }
  174. const uploadFile = (url, data, success) => {
  175. // console.log(env[env.NODE_ENV].apiUrl + url, data)
  176. getToken(token => {
  177. uni.uploadFile({
  178. url: env[env.NODE_ENV].apiUrl + url,
  179. filePath: data,
  180. name: 'file',
  181. header: {
  182. 'appId': header['appId'],
  183. 'authorityToken': token
  184. },
  185. success(res) {
  186. if (res.statusCode !== 200) return msg('文件上传失败');
  187. let data = JSON.parse(res.data);
  188. if (data.code !== 0) return msg(data.msg);
  189. success.call(this, data.data);
  190. },
  191. })
  192. })
  193. }
  194. /**弹窗 */
  195. const msg = (title, success) => {
  196. if (title) {
  197. uni.showToast({
  198. title: title,
  199. icon: 'none',
  200. success() {
  201. if (success) success.call(this);
  202. }
  203. });
  204. }
  205. return false;
  206. }
  207. const load = msg => {
  208. uni.showLoading({
  209. title: msg,
  210. mask: true
  211. })
  212. }
  213. // 去掉字符串中的特殊字符和转义字符
  214. const excludeSpecial = (s) => {
  215. // 去掉转义字符
  216. // s = s.replace(/[\'\"\\\/\b\f\n\r\t]/g, '');
  217. const pattern = /[`~!@#$^&*()=|{}':;',\\\[\]\.<>\/?~!@#¥……&*()——|{}【】';:""' + - - _ % 。,、?\s]/g;
  218. if (s != undefined || s != null) {
  219. s = s.replace(pattern, "")
  220. }
  221. return s;
  222. }
  223. const setStorage = (key, value) => {
  224. uni.setStorageSync(env.NODE_ENV + "_" + key, value)
  225. }
  226. const getStorage = (key) => {
  227. return uni.getStorageSync(env.NODE_ENV + "_" + key)
  228. }
  229. const removeStorage = (key) => {
  230. return uni.removeStorageSync(env.NODE_ENV + "_" + key);
  231. }
  232. const silenceLogin = (saleNo) => {
  233. return new Promise((resolve, reject) => {
  234. let params = {
  235. saleNo: saleNo
  236. }
  237. // if(getStorage('userInfo')){
  238. // resolve();
  239. // }else{
  240. // postRequest('/api/h5/login', params, data => {
  241. // if(data) setStorage('userInfo', data);
  242. // if (data.token) setStorage('AUTH_TOKEN', data.token);
  243. // resolve();
  244. // });
  245. // }
  246. postRequest('/api/h5/login', params, data => {
  247. if(data) setStorage('userInfo', data);
  248. if (data.token) setStorage('AUTH_TOKEN', data.token);
  249. resolve();
  250. });
  251. });
  252. }
  253. module.exports = {
  254. setStorage: setStorage,
  255. getStorage: getStorage,
  256. postRequest: postRequest,
  257. postRequestLoding: postRequestLoding,
  258. getRequest: getRequest,
  259. putRequest: putRequest,
  260. putRequestJson: putRequestJson,
  261. msg: msg,
  262. load: load,
  263. getToken: getToken,
  264. loadIng: loadIng,
  265. removeStorage: removeStorage,
  266. public: publics,
  267. header: header,
  268. excludeSpecial: excludeSpecial,
  269. silenceLogin:silenceLogin,
  270. uploadFile:uploadFile
  271. }