KdYdDeliveryServiceImpl.java 19 KB

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