request.js 7.0 KB

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