From bb553634dfca6d5df3311f89c69eacced5e01e74 Mon Sep 17 00:00:00 2001 From: CZT <czt18638530771@163.com> Date: 星期四, 14 十二月 2023 19:33:31 +0800 Subject: [PATCH] 更新上海粮情数据封装接口 --- src/main/java/com/fzzy/push/sh2023/SH2023ApiRemoteService.java | 264 ++++++++++++++++++++++++++++++++++++++++++++-------- 1 files changed, 223 insertions(+), 41 deletions(-) diff --git a/src/main/java/com/fzzy/push/sh2023/SH2023ApiRemoteService.java b/src/main/java/com/fzzy/push/sh2023/SH2023ApiRemoteService.java index 6870ad1..1499170 100644 --- a/src/main/java/com/fzzy/push/sh2023/SH2023ApiRemoteService.java +++ b/src/main/java/com/fzzy/push/sh2023/SH2023ApiRemoteService.java @@ -16,6 +16,7 @@ import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang.StringUtils; import org.apache.commons.lang.time.DateFormatUtils; +import com.fzzy.api.utils.NumberUtil; import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; @@ -58,6 +59,8 @@ private Api1202Rep api1202Rep; @Autowired private Api1205Rep api1205Rep; + @Autowired + private Api1403Rep api1403Rep; @Autowired private Api1404Rep api1404Rep; @@ -154,6 +157,64 @@ resd.setSuccess(responseDto.getCode() == 200 ? 0 : responseDto.getCode()); resd.setMsg(responseDto.getResult()); + return resd; + } catch (Exception e) { + log.error(e.getMessage(), e); + return new ResponseDto(99, e.getMessage()); + } + } + + @Override + public ResponseDto pullData(ApiParam param, ApiConfs conf) { + String inteId = param.getInteId(); + String kqdm = param.getKqdm(); + + try { + if (null == conf) { + conf = apiCommonService.getConf(kqdm); + } + + //娣诲姞鏃ュ織 + ApiLog apiLog = new ApiLog(); + apiLog.setId(ContextUtil.getUUID()); + apiLog.setInteId(inteId); + + if (StringUtils.isEmpty(inteId)) { + ResponseDto responseDto = new ResponseDto(99, "娌℃湁鑾峰彇鍒版帴鍙�"); + apiLog.setStatus(99); + apiLog.setResult("娌℃湁鑾峰彇鍒版帴鍙�"); + apiLogRep.save(apiLog); + return responseDto; + } + + if (conf == null) { + ResponseDto responseDto = new ResponseDto(99, "娌℃湁鑾峰彇鍒颁笂浼犻厤缃�"); + apiLog.setStatus(99); + apiLog.setResult("娌℃湁鑾峰彇鍒颁笂浼犻厤缃�"); + apiLogRep.save(apiLog); + return responseDto; + } + + //鏌ヨ搴撳尯淇℃伅琛屾斂鍖哄垝鐮� + List<Api1102> api1102List = api1102Rep.findPushData(kqdm); + //灏佽鏁版嵁 + SH2023PullReqDto reqData = new SH2023PullReqDto();; + + reqData.setName(conf.getUserName()); + reqData.setPwd(conf.getAppCode()); + + log.info("鎷夊彇鍏变韩鏁版嵁璇锋眰淇℃伅=" + JSON.toJSONString(reqData)); + + String url = conf.getApiUrl().replace("UPLOAD", "Shared"); + SH2023PullRespDto responseDto = SH2023HttpClientUtil.postPullData(url + inteId, JSON.toJSONString(reqData)); + + apiLog.setStatus(responseDto.getRetcode() == 200 ? 0 : responseDto.getRetcode()); + apiLog.setResult(responseDto.getRetMsg()); + apiLogRep.save(apiLog); + ResponseDto resd = new ResponseDto(); + resd.setSuccess(responseDto.getRetcode() == 200 ? 0 : responseDto.getRetcode()); + resd.setMsg(responseDto.getRetMsg()); + resd.setData(responseDto.getData()); return resd; } catch (Exception e) { log.error(e.getMessage(), e); @@ -293,6 +354,8 @@ api1109.setWjl(JSON.toJSONString(map)); //涓婃捣甯傚钩鍙版枃浠跺悕绉拌鍒欙細搴撳尯缂栫爜_涓氬姟娴佹按鍙穇鍒嗙被鐮乢椤哄簭鐮�.jpg锛屼緥濡傦細91310114703439394M001_142211080101_GL_00.jpg api1109.setWjmc(getWjmc(api1109.getWjlx(), api1109.getWjmc())); + //涓氬姟绫诲瀷 + api1109.setYwdh(getYwdh(api1109.getWjlx(), api1109.getWjmc())); //璁剧疆绌哄睘鎬т负榛樿鍊� changeObject(api1109); return api1109; @@ -351,6 +414,11 @@ if (StringUtils.isEmpty(api1201.getShr())) { api1201.setShr("瀹℃壒浜�"); } + //璁剧疆璐攢鏂瑰紡,榛樿瀹㈡埛缁熶竴淇$敤鐮佷负绌猴紝鍒欎负浜ч攢锛屽弽涔嬩负绔炰环锛�(1-瀹氬悜锛�2-绔炰环锛�3-浜ч攢) + api1201.setGxfs("2"); + if(StringUtils.isEmpty(api1201.getKhtyshxydm())){ + api1201.setGxfs("3"); + } //璁剧疆绌哄睘鎬т负榛樿鍊� changeObject(api1201); return api1201; @@ -371,7 +439,12 @@ //璁剧疆绮杞崲骞村害 List<Api1404> api1404List = api1404Rep.getDataByJhmxdh(apiData.getJhmxh()); if (null != api1404List && api1404List.size() > 0) { - api1202.setLhnd(api1404List.get(0).getShnd()); + List<Api1403> api1403List = api1403Rep.getDataByLhjhdh(api1404List.get(0).getLhjhdh()); + if(null != api1403List && api1403List.size() > 0){ + if(StringUtils.isNotEmpty(api1403List.get(0).getJhnd())){ + api1202.setLhnd(api1403List.get(0).getJhnd()); + } + } } //璁剧疆鎵规鍙� @@ -455,7 +528,12 @@ //璁剧疆绮杞崲骞村害 List<Api1404> api1404List = api1404Rep.getDataByJhmxdh(apiData.getJhmxh()); if (null != api1404List && api1404List.size() > 0) { - api1205.setLhnd(api1404List.get(0).getShnd()); + List<Api1403> api1403List = api1403Rep.getDataByLhjhdh(api1404List.get(0).getLhjhdh()); + if(null != api1403List && api1403List.size() > 0){ + if(StringUtils.isNotEmpty(api1403List.get(0).getJhnd())){ + api1205.setLhnd(api1403List.get(0).getJhnd()); + } + } } //璁剧疆鎵规鍙� @@ -596,16 +674,14 @@ Api1302 apiData = (Api1302) data; BeanUtils.copyProperties(apiData, api1302); api1302.setBjw(ShAreaBjw.getBjw(code)); - api1302.setCpjw(String.valueOf(apiData.getLspjw())); - api1302.setCzgw(String.valueOf(apiData.getLspjw())); - api1302.setCzdw(String.valueOf(apiData.getLspjw())); - api1302.setGfwjw(String.valueOf(apiData.getLspjw())); - api1302.setLwmx(apiData.getLswdzjh()); - + api1302.setLqjs("1"); + //鎵规鍙� List<Api1208> api1208List = api1208Rep.findDataByHwdm(api1302.getHwdm()); if (null != api1208List && api1208List.size() > 0) { api1302.setPch(apiData.getHwdm() + api1208List.get(0).getShnd()); } + //缁熻灞傞珮銆佸眰浣庛�佸眰鍧囨俯绛変俊鎭� + api1302 = packageData1302(api1302); //璁剧疆绌哄睘鎬т负榛樿鍊� changeObject(api1302); @@ -837,16 +913,124 @@ return data; } - private String getWjmc(String wjlx, String wjmc) { - if ("2".equals(wjlx) || "3".equals(wjlx) || "4".equals(wjlx) || "5".equals(wjlx)) { - if (wjmc.endsWith(".jpg")) { - wjmc = wjmc.replaceAll(".jpg", "_00.jpg"); + /** + * 鏍规嵁涓婃捣鏁版嵁鏍煎紡杩涜灏佽 + * 灞傚潎娓╋細 + * 灞傞珮娓╋細 + * 灞備綆娓╋細 + * 鍚勮寖鍥村潎娓╋細 + * 绮俯鏄庣粏锛� + * 绮俯鐘舵�侊細 + * 寮傚父鐐逛釜鏁帮細 + * + * @param data + * @return + */ + private SH2023Api1302 packageData1302(SH2023Api1302 data) { + if (StringUtils.isEmpty(data.getLswdzjh())) { + return data; + } + String lswdzjh = data.getLswdzjh(); + String[] split = lswdzjh.split("\\|"); + Map<Integer, List<Double>> map = new HashMap<>(); + Integer ceng; + Integer errorNum = 0; //寮傚父鐐逛釜鏁� + String lwmx = ""; //绮俯鏄庣粏 + String lwzt = "0"; //绮俯鐘舵�� + String gfwjw = ""; //鍚勮寖鍥村潎娓� + for (String s : split) { + String[] grain = s.split(","); + ceng = Integer.valueOf(grain[1]); + if (null == map.get(ceng)) { + map.put(ceng, new ArrayList<>()); } - if (wjmc.endsWith(".png")) { - wjmc = wjmc.replaceAll(".png", "_00.png"); + map.get(ceng).add(Double.valueOf(grain[0])); + lwmx += grain[3] + ":" + grain[2] + ":" + grain[1] + "$" + grain[0]; + if (Double.valueOf(grain[0]) <= -100) { + lwmx += "$" + "1" + "#"; + errorNum++; + } else { + lwmx += "$" + "5" + "#"; } } - return wjmc; + String cpjw = ""; //灞傚钩鍧囨俯 + String czgw = ""; //灞傛渶楂樻俯 + String czdw = ""; //灞傛渶浣庢俯 + + List<Double> payPoints; + Double sum; + int num; + Double tempH; + Double tempL; + Double tempA; + Double tempValue1 = 0.0; //鑼冨洿鍧囨俯1 + Double tempValue2 = 0.0; //鑼冨洿鍧囨俯2 + Double tempValue3 = 0.0; //鑼冨洿鍧囨俯3 + Integer numValue = 0; //璁$畻鑼冨洿鍧囨俯 + for (Integer cengNum : map.keySet()) { + payPoints = map.get(cengNum); + sum = 0.0; + num = 0; + tempH = null; + tempL = null; + tempA = 0.0; + for (Double point : payPoints) { + if(point > -100){ + sum += point; + num++; + if (tempH == null) { + tempH = point; + } + if (tempL == null) { + tempL = point; + } + if (tempH < point) { + tempH = point; + } + if (tempL > point) { + tempL = point; + } + } + } + if (num > 0) { + tempA = sum / num; + } + cpjw += cengNum + "$" + NumberUtil.keepPrecision(tempA, 1) + "#"; + czgw += cengNum + "$" + tempH + "#"; + czdw += cengNum + "$" + tempL + "#"; + //鑼冨洿鍧囨俯灏佽 + if (cengNum == 1) { + tempValue1 = NumberUtil.keepPrecision(tempA, 1); + } else if (cengNum == map.keySet().size()) { + tempValue3 = NumberUtil.keepPrecision(tempA, 1); + } else { + tempValue2 += tempA; + numValue++; + } + } + + if (errorNum > 0) { + lwzt = "2"; + } + if (numValue > 0) { + tempValue2 = NumberUtil.keepPrecision(tempValue2 / numValue, 1); + } + gfwjw += tempValue1 + "#"; + if (map.keySet().size() == 2) { + gfwjw += tempValue3 + "#"; + } + if (map.keySet().size() > 3) { + gfwjw += tempValue2 + "#" + tempValue3 + "#"; + } + data.setCpjw(cpjw); + data.setCzgw(czgw); + data.setCzdw(czdw); + data.setGfwjw(gfwjw); + data.setLwmx(lwmx); + data.setLwzt(lwzt); + data.setYcdgs(errorNum); + + return data; } /** @@ -867,28 +1051,7 @@ } } - /** - * Object绫诲瀷杞彉涓篖ist - * - * @param obj - * @param clazz - * @param <T> - * @return - */ - public static <T> List<T> castList(Object obj, Class<T> clazz) { - List<T> result = new ArrayList<T>(); - if (obj instanceof List<?>) { - for (Object o : (List<?>) obj) { - result.add(clazz.cast(o)); - } - return result; - } - return null; - } - - - private List<SHFinanceDto> copyApi1503(Api1503 data) { - Api1503 api1503 = data; + private List<SHFinanceDto> copyApi1503(Api1503 api1503) { List<SHFinanceDto> list = new ArrayList<>(); SHFinanceDto shFinanceDto = new SHFinanceDto(); shFinanceDto.setDwdm(api1503.getDwdm()); @@ -938,8 +1101,7 @@ return list; } - private List<SHFinanceDto> copyApi1502(Api1502 data) { - Api1502 api1502 = data; + private List<SHFinanceDto> copyApi1502(Api1502 api1502) { List<SHFinanceDto> list = new ArrayList<>(); SHFinanceDto shFinanceDto = new SHFinanceDto(); shFinanceDto.setDwdm(api1502.getDwdm()); @@ -991,8 +1153,7 @@ return list; } - private List<SHFinanceDto> copyApi1501(Api1501 data) { - Api1501 api1501 = data; + private List<SHFinanceDto> copyApi1501(Api1501 api1501) { List<SHFinanceDto> list = new ArrayList<>(); SHFinanceDto shFinanceDto = new SHFinanceDto(); shFinanceDto.setDwdm(api1501.getDwdm()); @@ -1089,6 +1250,26 @@ list.add(shFinanceDto); } + private String getWjmc(String wjlx, String wjmc) { + if ("2".equals(wjlx) || "3".equals(wjlx) || "4".equals(wjlx) || "5".equals(wjlx)) { + if (wjmc.endsWith(".jpg")) { + wjmc = wjmc.replaceAll(".jpg", "_00.jpg"); + } + if (wjmc.endsWith(".png")) { + wjmc = wjmc.replaceAll(".png", "_00.png"); + } + } + return wjmc; + } + private String getYwdh(String wjlx, String wjmc) { + String ywdh = ""; + String[] s = wjmc.split("_"); + if ("2".equals(wjlx) || "3".equals(wjlx)) { + ywdh = s[1]; + } + return ywdh; + } + private Object changeObject(Object object) { // 浣跨敤鍙嶅皠鑾峰彇灞炴�у垪琛� vo涓哄疄浣撳璞″悕 Field[] fields = object.getClass().getDeclaredFields(); @@ -1117,4 +1298,5 @@ } return object; } + } \ No newline at end of file -- Gitblit v1.9.3