KdYdDeliveryServiceImpl.java 19 KB

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