KdYdDeliveryServiceImpl.java 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441
  1. package com.malk.huagao.service.impl;
  2. import cn.hutool.http.HttpRequest;
  3. import cn.hutool.http.HttpResponse;
  4. import com.alibaba.fastjson.JSON;
  5. import com.alibaba.fastjson.JSONArray;
  6. import com.alibaba.fastjson.JSONObject;
  7. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  8. import com.malk.huagao.entity.*;
  9. import com.malk.huagao.mapper.KdYdDeliveryDetailMapper;
  10. import com.malk.huagao.mapper.KdYdDeliveryMapper;
  11. import com.malk.huagao.mapper.KdYdOrderDetailMapper;
  12. import com.malk.huagao.mapper.KdYdOrderMapper;
  13. import com.malk.huagao.service.IKdYdDeliveryService;
  14. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  15. import com.malk.server.aliwork.YDConf;
  16. import com.malk.server.aliwork.YDParam;
  17. import com.malk.server.dingtalk.DDR_New;
  18. import com.malk.service.aliwork.YDClient;
  19. import com.malk.utils.UtilMap;
  20. import lombok.extern.slf4j.Slf4j;
  21. import org.apache.commons.lang3.StringEscapeUtils;
  22. import org.slf4j.MDC;
  23. import org.springframework.beans.factory.annotation.Autowired;
  24. import org.springframework.beans.factory.annotation.Value;
  25. import org.springframework.stereotype.Service;
  26. import java.math.BigDecimal;
  27. import java.math.RoundingMode;
  28. import java.time.Instant;
  29. import java.time.LocalDateTime;
  30. import java.time.ZoneId;
  31. import java.util.*;
  32. /**
  33. * <p>
  34. * 服务实现类
  35. * </p>
  36. *
  37. * @author LQY
  38. * @since 2025-10-15
  39. */
  40. @Service
  41. @Slf4j
  42. public class KdYdDeliveryServiceImpl extends ServiceImpl<KdYdDeliveryMapper, KdYdDelivery> implements IKdYdDeliveryService {
  43. @Autowired
  44. private YDClient ydClient;
  45. @Autowired
  46. private KdYdDeliveryMapper kdYdDeliveryMapper;
  47. @Autowired
  48. private KdYdDeliveryDetailMapper kdYdDeliveryDetailMapper;
  49. @Value(value = "${kd.host}")
  50. private String kdHost;
  51. @Override
  52. public Map<String, Object> insertDelivery(Map map) {
  53. Map<String, Object> result = new HashMap<>();
  54. try {
  55. MDC.put("MDC_KEY_PID", "1003");
  56. String formInstId = UtilMap.getString(map, "formInstId");
  57. String action = UtilMap.getString(map, "type");
  58. // 处理特殊操作类型
  59. if ("del".equals(action)) {
  60. String bm = UtilMap.getString(map, "bm");
  61. Map<String, String> headers = new HashMap<>();
  62. headers.put("Content-Type", "application/x-www-form-urlencoded");
  63. Map<String, Object> formParams = new HashMap<>();
  64. Map<String, Object> djbh = new HashMap<>();
  65. djbh.put("djbh", bm);
  66. result.put("data", djbh);
  67. String jsonStr = JSON.toJSONString(result);
  68. formParams.put("jsons", jsonStr);
  69. HttpResponse response = HttpRequest.post(kdHost+"/xk/dyzn/WsBasedyzn.asmx/hgdjydtbdeletefhtzd")
  70. .headerMap(headers, true)
  71. .form(formParams)
  72. .timeout(30000) // 30秒超时
  73. .execute();
  74. String responseBody = response.body();
  75. System.out.println("responseBody===="+responseBody);
  76. // 返回删除操作的格式
  77. result.put("table", "KD_YD_DELIVERY");
  78. result.put("action", "del");
  79. result.put("data", new HashMap<String, Object>() {{
  80. put("bm", bm); // 删除的主键或标识
  81. put("msg", "删除成功");
  82. }});
  83. return result;
  84. }
  85. // 查询表单数据
  86. DDR_New ddrNew = ydClient.queryData(YDParam.builder()
  87. .formInstId(formInstId)
  88. .build(), YDConf.FORM_QUERY.retrieve_id);
  89. Map formData = ddrNew.getFormData();
  90. // 提取主表字段
  91. String djlx = UtilMap.getString(formData, "selectField_mg3fuqvg");
  92. String orderId = UtilMap.getString(formData, "textField_mf6a0h6f");
  93. LocalDateTime rq = parseTimestamp(UtilMap.getString(formData, "dateField_krbgloam"));
  94. String kh = UtilMap.getString(formData, "textField_mejnamf2");
  95. String jsbb = UtilMap.getString(formData, "selectField_mg3fuqvn");
  96. String djbh = UtilMap.getString(formData, "serialNumberField_mheazm7w");
  97. String xsbm = UtilMap.getString(formData, "textField_krnn5bmr");
  98. String lllx = UtilMap.getString(formData, "selectField_mejowmnc");
  99. String jjr = UtilMap.getString(formData, "textField_mf6a0h5f");
  100. String jjrdh = UtilMap.getString(formData, "textField_mf6a0h5g");
  101. String jjdz = UtilMap.getString(formData, "textareaField_mf6a0h5h");
  102. String xslx = UtilMap.getString(formData, "selectField_mgrn6p2d");
  103. String bzfs = UtilMap.getString(formData, "selectField_mf6a0h5y");
  104. String bz = UtilMap.getString(formData, "textareaField_mejnamfb");
  105. // LocalDateTime hhsj = parseTimestamp(UtilMap.getString(formData, "dateField_mf6a0h67"));
  106. LocalDateTime hhsj = Optional.ofNullable(
  107. parseTimestamp(UtilMap.getString(formData, "dateField_mf6a0h67"))
  108. )
  109. .orElseGet(() -> LocalDateTime.now()
  110. .withHour(17)
  111. .withMinute(0)
  112. .withSecond(0)
  113. .withNano(0));
  114. String ysfs = UtilMap.getString(formData, "selectField_mf6a0h5z");
  115. String hdfs = UtilMap.getString(formData, "selectField_mf6a0h60");
  116. String kdgs = UtilMap.getString(formData, "selectField_mf6a0h61");
  117. String fkfs = UtilMap.getString(formData, "selectField_mf6a0h66");
  118. // 处理明细数据
  119. List<Map<String, Object>> deliveryList = new ArrayList<>();
  120. List<Map> tableField = (List<Map>) formData.get("tableField_mejnamfd");
  121. if (tableField != null && !tableField.isEmpty()) {
  122. int detailId = 1;
  123. for (Map item : tableField) {
  124. Map<String, Object> table1Map = new HashMap<>();
  125. // int detailId = parseInt(safeGetString(item, "numberField_mjzg06br"), 0);
  126. String wlbm = safeGetString(item, "textField_mejnamff");
  127. String wlmc = safeGetString(item, "textField_mejnamfg");
  128. String ggxh = safeGetString(item, "textField_mejnamfh");
  129. String xsdw = safeGetString(item, "textField_mejnamfk");
  130. int jjsl = parseInt(safeGetString(item, "numberField_mf6a0h6r"), 0);
  131. // int count = parseInt(safeGetString(item, "numberField_mjzg06br"), 0);
  132. String ssxl = safeGetString(item, "textField_mejnamfx");
  133. String sfzp = safeGetString(item, "radioField_mf6a0h6h");
  134. String ckck = safeGetString(item, "textField_mf6a0h6l");
  135. String ckcw = safeGetString(item, "textField_mf6a0h6k");
  136. String sjr = safeGetString(item, "textField_mejnamf6");
  137. String sjdh = safeGetString(item, "textField_mejnamf7");
  138. String sjdz = safeGetString(item, "textareaField_mf6a0h5e");
  139. String zbq = safeGetString(item, "numberField_mf6a0h6v");
  140. String kddh = safeGetString(item, "textField_mf6a0h6w");
  141. String mdh = safeGetString(item, "textField_mf6a0h6y");
  142. LocalDateTime yhrq = parseTimestamp(safeGetString(item, "dateField_mejnamfo"));
  143. table1Map.put("wlbm", wlbm);
  144. table1Map.put("detailId", detailId);
  145. table1Map.put("wlmc", wlmc);
  146. table1Map.put("ggxh", ggxh);
  147. table1Map.put("xsdw", xsdw);
  148. table1Map.put("jjsl", jjsl);
  149. // table1Map.put("count", count);
  150. table1Map.put("ssxl", ssxl);
  151. table1Map.put("yhrq", yhrq);
  152. table1Map.put("sfzp", sfzp);
  153. table1Map.put("ckck", ckck);
  154. table1Map.put("ckcw", ckcw);
  155. table1Map.put("sjr", sjr);
  156. table1Map.put("sjdh", sjdh);
  157. table1Map.put("sjdz", sjdz);
  158. table1Map.put("zbq", zbq);
  159. table1Map.put("kddh", kddh);
  160. table1Map.put("mdh", mdh);
  161. deliveryList.add(table1Map);
  162. detailId++;
  163. }
  164. }
  165. // 构建返回数据
  166. Map<String, Object> deliveryData = new HashMap<>();
  167. deliveryData.put("djlx", djlx);
  168. deliveryData.put("orderId", orderId);
  169. deliveryData.put("rq", rq);
  170. deliveryData.put("kh", kh);
  171. deliveryData.put("jsbb", jsbb);
  172. deliveryData.put("djbh", djbh);
  173. deliveryData.put("xsbm", xsbm);
  174. deliveryData.put("lllx", lllx);
  175. deliveryData.put("jjr", jjr);
  176. deliveryData.put("jjrdh", jjrdh);
  177. deliveryData.put("jjdz", jjdz);
  178. deliveryData.put("xslx", xslx);
  179. deliveryData.put("bzfs", bzfs);
  180. deliveryData.put("bz", bz);
  181. deliveryData.put("hhsj", hhsj);
  182. deliveryData.put("ysfs", ysfs);
  183. deliveryData.put("hdfs", hdfs);
  184. deliveryData.put("kdgs", kdgs);
  185. deliveryData.put("fkfs", fkfs);
  186. deliveryData.put("DeliveryList", deliveryList);
  187. Map<String, String> headers = new HashMap<>();
  188. headers.put("Content-Type", "application/x-www-form-urlencoded");
  189. result.put("data", deliveryData);
  190. // 将result转换为JSON字符串
  191. String jsonStr = JSON.toJSONString(result);
  192. // 构建form参数
  193. Map<String, Object> formParams = new HashMap<>();
  194. formParams.put("jsons", jsonStr);
  195. log.info("请求参数:" + formParams);
  196. // 发送请求
  197. HttpResponse response = null;
  198. if ("add".equals(action)) {
  199. response = HttpRequest.post(kdHost+"/xk/dyzn/WsBasedyzn.asmx/hgdjydtbcreatefhtzd")
  200. .headerMap(headers, true)
  201. .form(formParams)
  202. .timeout(30000) // 30秒超时
  203. .execute();
  204. } else {
  205. response = HttpRequest.post(kdHost+"/xk/dyzn/WsBasedyzn.asmx/")
  206. .headerMap(headers, true)
  207. .form(formParams)
  208. .timeout(30000) // 30秒超时
  209. .execute();
  210. }
  211. String responseBody = response.body();
  212. log.info("返回结果responseBody:" + responseBody);
  213. try {
  214. String msg = JSON.parseArray(responseBody)
  215. .getJSONObject(0)
  216. .getString("msg");
  217. String code = JSON.parseArray(responseBody)
  218. .getJSONObject(0)
  219. .getString("code");
  220. ydClient.operateData(
  221. YDParam.builder()
  222. .formInstanceId(formInstId)
  223. .updateFormDataJson(JSONObject.toJSONString(UtilMap.map("textField_ml08nk3y, textareaField_mkz9u4p9", code, msg)))
  224. .useLatestVersion(true).build(),
  225. YDConf.FORM_OPERATION.update);
  226. } catch (Exception e) {
  227. System.out.println("解析JSON失败: " + e.getMessage());
  228. }
  229. } catch (Exception e) {
  230. log.error("发货通知单同步异常", e);
  231. result.put("table", "KD_YD_DELIVERY");
  232. result.put("action", "error");
  233. result.put("data", new HashMap<String, Object>() {{
  234. put("errorMsg", "操作失败:" + e.getMessage());
  235. }});
  236. }
  237. return result;
  238. }
  239. @Override
  240. public void CfkdYdDelivery(Map map) {
  241. MDC.put("MDC_KEY_PID", "1003");
  242. String formInstId = UtilMap.getString(map, "formInstId");
  243. // 查询原表单数据
  244. DDR_New ddrNew = ydClient.queryData(
  245. YDParam.builder().formInstId(formInstId).build(),
  246. YDConf.FORM_QUERY.retrieve_id
  247. );
  248. Map formData1 = ddrNew.getFormData();
  249. // 提取需要特殊处理的主表字段
  250. String glbdjson = String.valueOf(formData1.get("associationFormField_mejmml36_id"));
  251. String sqr = String.valueOf(formData1.get("employeeField_krbgloal_id"));
  252. String xsy = String.valueOf(formData1.get("employeeField_mejnamf3_id"));
  253. String fhtzd = String.valueOf(formData1.get("serialNumberField_mheazm7w"));
  254. // 解析关联字段 JSON
  255. List<Map> sealjsonlist = parseJsonList(glbdjson);
  256. // 获取原表单的子表数据
  257. List<Map> tableField = UtilMap.getList(formData1, "tableField_mejnamfd");
  258. if (tableField == null || tableField.isEmpty()) {
  259. return;
  260. }
  261. // 按 dz 分组
  262. Map<String, List<Map>> groupedByDz = new LinkedHashMap<>();
  263. for (Map item : tableField) {
  264. String dz = UtilMap.getString(item, "textareaField_mf6a0h5e");
  265. if (dz == null) dz = "";
  266. groupedByDz.computeIfAbsent(dz, k -> new ArrayList<>()).add(item);
  267. }
  268. // 对每个 dz 分组,创建一条新表单
  269. for (Map.Entry<String, List<Map>> entry : groupedByDz.entrySet()) {
  270. String dz = entry.getKey();
  271. List<Map> subTableRows = entry.getValue();
  272. // 构建新子表数据
  273. List<Map> newSubTable = new ArrayList<>();
  274. for (Map row : subTableRows) {
  275. newSubTable.add(new HashMap<>(row));
  276. }
  277. // 构建新表单的formData
  278. HashMap<String, Object> updateMap = new HashMap<>();
  279. // 1. 首先复制原表单的所有主表数据
  280. for (Object obj : formData1.entrySet()) {
  281. Map.Entry<String, Object> formEntry = (Map.Entry<String, Object>) obj;
  282. String key = formEntry.getKey();
  283. Object value = formEntry.getValue();
  284. // 跳过不需要特殊处理的子表字段
  285. if ("tableField_mejnamfd".equals(key)) {
  286. continue;
  287. }
  288. // 跳过需要特殊处理的主表关联字段
  289. if (key.equals("associationFormField_mejmml36_id") ||
  290. key.equals("associationFormField_mfavc4ve_id") ||
  291. key.equals("associationFormField_mk0gzflu_id") ||
  292. key.equals("employeeField_krbgloal_id") ||
  293. key.equals("employeeField_mejnamf3_id") ||
  294. key.equals("serialNumberField_mheazm7w")) {
  295. continue;
  296. }
  297. // 复制其他字段
  298. updateMap.put(key, value);
  299. }
  300. // 2. 添加需要特殊处理的主表字段
  301. updateMap.put("associationFormField_mejmml36", sealjsonlist);
  302. // updateMap.put("associationFormField_mfavc4ve", khjsonlist);
  303. updateMap.put("associationFormField_mk0gzflu", Arrays.asList(getfhdAss(fhtzd, formInstId)));
  304. updateMap.put("employeeField_krbgloal", sqr);
  305. updateMap.put("employeeField_mejnamf3", xsy);
  306. updateMap.put("textField_mjzk47so", fhtzd);
  307. // 3. 添加处理后的子表数据
  308. updateMap.put("tableField_mejnamfd", newSubTable);
  309. String sqrid = sqr.substring(2, sqr.length() - 2);
  310. System.out.println("sqrid==" + sqrid);
  311. // 创建新表单实例
  312. try {
  313. ydClient.operateData(
  314. YDParam.builder()
  315. .formUuid("FORM-FAE2575E112644ED914CAB4FEC9309F32AVR")
  316. .formDataJson(JSON.toJSONString(updateMap))
  317. .userId(sqrid)
  318. .build(),
  319. YDConf.FORM_OPERATION.create
  320. );
  321. } catch (Exception e) {
  322. log.error("创建新单据失败,dz=" + dz, e);
  323. }
  324. }
  325. }
  326. // 工具方法:安全解析 JSON 列表(处理宜搭返回的带引号字符串)
  327. private List<Map> parseJsonList(String jsonStr) {
  328. if (jsonStr == null || "null".equals(jsonStr) || jsonStr.isEmpty()) {
  329. return Collections.emptyList();
  330. }
  331. try {
  332. // 宜搭有时返回的是 "\"[{...}]\"",需先 unescape
  333. String clean = StringEscapeUtils.unescapeJava(jsonStr);
  334. // 如果首尾是双引号,去掉
  335. if (clean.startsWith("\"") && clean.endsWith("\"")) {
  336. clean = clean.substring(1, clean.length() - 1);
  337. }
  338. return (List<Map>) JSONArray.parse(clean);
  339. } catch (Exception e) {
  340. return Collections.emptyList();
  341. }
  342. }
  343. private Object getfhdAss(String title, String id) {
  344. return UtilMap.map("appType, formUuid, formType, instanceId, title, subTitle", "APP_VQDMMWS6OR1VHL8VMFD3", "FORM-A7F03ACEE01D4F609550C86BF7FE87D35M6I", "receipt", id, title, "");
  345. }
  346. private static LocalDateTime parseTimestamp(String timestampStr) {
  347. if (timestampStr == null || timestampStr.trim().isEmpty()) return null;
  348. try {
  349. long timestamp = Long.parseLong(timestampStr.trim());
  350. return LocalDateTime.ofInstant(
  351. Instant.ofEpochMilli(timestamp),
  352. ZoneId.systemDefault()
  353. );
  354. } catch (NumberFormatException e) {
  355. return null;
  356. }
  357. }
  358. private static int parseInt(String str, int defaultValue) {
  359. if (str == null || str.trim().isEmpty()) {
  360. return defaultValue;
  361. }
  362. try {
  363. return Integer.parseInt(str.trim());
  364. } catch (NumberFormatException e) {
  365. return defaultValue;
  366. }
  367. }
  368. private String safeGetString(Map formData, String key) {
  369. Object val = formData.get(key);
  370. return val == null ? "" : String.valueOf(val);
  371. }
  372. public static BigDecimal toBigDecimal(String str) {
  373. if (str == null || str.trim().isEmpty()) {
  374. return BigDecimal.ZERO.setScale(2, RoundingMode.HALF_UP);
  375. }
  376. try {
  377. return new BigDecimal(str.trim())
  378. .setScale(2, RoundingMode.HALF_UP);
  379. } catch (NumberFormatException e) {
  380. // 返回默认值而不是抛出异常,避免程序中断
  381. return BigDecimal.ZERO.setScale(2, RoundingMode.HALF_UP);
  382. }
  383. }
  384. /**
  385. * 重载方法,支持Number类型输入
  386. */
  387. public static BigDecimal toBigDecimal(Number number) {
  388. if (number == null) {
  389. return BigDecimal.ZERO.setScale(2, RoundingMode.HALF_UP);
  390. }
  391. return new BigDecimal(number.toString())
  392. .setScale(2, RoundingMode.HALF_UP);
  393. }
  394. }