From 44ec7c27cc897a710ff116d52a790f45ce081dcb Mon Sep 17 00:00:00 2001
From: 于杰 <1210123631@qq.com>
Date: 星期二, 30 十二月 2025 09:06:09 +0800
Subject: [PATCH] 修复  旋转错判问题

---
 north-glass-erp/src/main/java/com/example/erp/service/pp/GlassOptimizeService.java |  892 ++++++++++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 818 insertions(+), 74 deletions(-)

diff --git a/north-glass-erp/src/main/java/com/example/erp/service/pp/GlassOptimizeService.java b/north-glass-erp/src/main/java/com/example/erp/service/pp/GlassOptimizeService.java
index 3d029b8..48e877e 100644
--- a/north-glass-erp/src/main/java/com/example/erp/service/pp/GlassOptimizeService.java
+++ b/north-glass-erp/src/main/java/com/example/erp/service/pp/GlassOptimizeService.java
@@ -4,37 +4,32 @@
 import com.alibaba.fastjson.JSONArray;
 import com.alibaba.fastjson.JSONObject;
 import com.baomidou.dynamic.datasource.annotation.DS;
-import com.baomidou.mybatisplus.annotation.IdType;
-import com.baomidou.mybatisplus.annotation.TableId;
 import com.example.erp.common.RabbitMQUtil;
+import com.example.erp.dto.pp.MesCalculateDTO;
 import com.example.erp.entity.pp.*;
-import com.example.erp.entity.sd.Delivery;
-import com.example.erp.entity.sd.OrderDetail;
-import com.example.erp.entity.userInfo.Log;
 import com.example.erp.entity.userInfo.SysError;
 import com.example.erp.mapper.pp.GlassOptimizeMapper;
 import com.example.erp.service.userInfo.SysErrorService;
 import com.fasterxml.jackson.core.JsonProcessingException;
+import com.fasterxml.jackson.databind.DeserializationFeature;
 import com.fasterxml.jackson.databind.ObjectMapper;
 import com.fasterxml.jackson.datatype.jsr310.JavaTimeModule;
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.beans.factory.annotation.Value;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 import org.springframework.transaction.interceptor.TransactionAspectSupport;
 
 import java.io.BufferedReader;
-import java.io.IOException;
 import java.io.InputStreamReader;
 import java.io.OutputStream;
+import java.lang.reflect.Field;
 import java.math.BigDecimal;
 import java.net.HttpURLConnection;
 import java.net.URL;
 import java.nio.charset.StandardCharsets;
 import java.sql.Date;
-import java.text.DecimalFormat;
-import java.time.LocalDate;
 import java.util.*;
-import java.util.concurrent.TimeoutException;
 import java.util.stream.Collectors;
 
 @Service
@@ -45,6 +40,9 @@
     GlassOptimizeMapper glassOptimizeMapper;
     @Autowired
     SysErrorService sysErrorService;
+
+    @Value("${mesIp:localhost}")
+    private String mesIp;
 
     RabbitMQUtil rabbitMQUtil;
     //妯℃嫙璁$畻
@@ -270,6 +268,9 @@
 
             List<Map<String, Object>> objectMapList = (List<Map<String, Object>>) optimalResults.get("layouts");
             glassOptimizeMapper.addOptimizeLayout(objectMapList,projectId);
+            // 鏀堕泦鎵�鏈夐渶瑕佷繚瀛樼殑鐜荤拑鏄庣粏鏁版嵁
+            List<Map<String, Object>> allGlassDetails = new ArrayList<>();
+
             for(Map<String, Object> objectMap:objectMapList){
                 List<Map<String, Object>> objectMap2 = (List<Map<String, Object>>) objectMap.get("glassDetails");
                 //杩唬鐜荤拑鏄庣粏闆嗗悎澶勭悊浣欐枡鍜屽叾浠�
@@ -346,10 +347,40 @@
                         }
                     }
                 }
-                glassOptimizeMapper.addOptimizeDetail(objectMap2,projectId);
+                // 灏嗗綋鍓嶆壒娆$殑鐜荤拑鏄庣粏娣诲姞鍒版�诲垪琛ㄤ腑
+                allGlassDetails.addAll(objectMap2);
             }
 
-            glassOptimizeMapper.updateProjectOptimize(projectId, 1, optimalResults);
+            Map<String, Object> projectInfo = glassOptimizeMapper.getGlassProjectList(projectId);
+            if (projectInfo != null && Integer.parseInt(projectInfo.get("tempering_state").toString()) == 1) {
+                // tempering_state 涓� 1 鏃剁殑澶勭悊閫昏緫
+                glassOptimizeMapper.addOptimizeDetail(allGlassDetails,projectId);
+                List<OptimizeHeatDetail> optimizeHeatDetail = glassOptimizeMapper.selectOptimizeHeatDetail(projectId);
+                for (OptimizeHeatDetail projectdetail:optimizeHeatDetail){
+                    OptimizeDetail optimizeDetail=glassOptimizeMapper.selectOptimizeDetailById(projectId,projectdetail.getProcessId(),
+                            projectdetail.getOrderSort(),projectdetail.getLayer());
+                    glassOptimizeMapper.updateOptimizeDetail(optimizeDetail.getId(),projectdetail.getLayoutId(),projectdetail.getSort());
+                }
+            } else {
+                // tempering_state 涓� 0 鏃剁殑澶勭悊閫昏緫
+                glassOptimizeMapper.addOptimizeDetail(allGlassDetails,projectId);
+            }
+            List<Map<String, Object>> materialStoreList = glassOptimizeMapper.materialStoreOptimizeUse(projectId);
+            double totalUseArea = 0.0;
+            for (Map<String, Object> material : materialStoreList) {
+                if (material.containsKey("totalArea")) {
+                    Object totalAreaObj = material.get("totalArea");
+                    if (totalAreaObj != null) {
+                        try {
+                            double area = Double.parseDouble(totalAreaObj.toString());
+                            totalUseArea += area;
+                        } catch (NumberFormatException e) {
+                            System.err.println("鏃犳硶瑙f瀽鎬婚潰绉暟鎹�: " + totalAreaObj);
+                        }
+                    }
+                }
+            }
+            glassOptimizeMapper.updateProjectOptimize(projectId, 1, optimalResults, totalUseArea);
             return true;
         } catch (Exception e) {
             e.printStackTrace();
@@ -602,6 +633,10 @@
         } else {
             dataList = glassOptimizeMapper.directOptimization(projectNo);
         }
+        List<Map<String, Object>> tempDataList = null;
+        if (Integer.parseInt(stringObjectMap.get("optimize_state").toString())==1) {
+            tempDataList = glassOptimizeMapper.optimizeTemp(projectNo);
+        }
 
         // 鑾峰彇纾ㄩ噺閰嶇疆鏁版嵁
         List<Map<String, Object>> grindingTrimmingList = glassOptimizeMapper.getGrindingOptimize(username);
@@ -620,7 +655,13 @@
                 }
             }
         }
+        if (tempDataList != null && !tempDataList.isEmpty()) {
+            dataList.addAll(tempDataList);
+        }
+        map.put("optimizeState", Integer.parseInt(stringObjectMap.get("optimize_state").toString()));
         map.put("data", dataList);
+        map.put("project", glassOptimizeMapper.selectProjectCount(projectNo));
+        map.put("grindingTrimming", glassOptimizeMapper.getGrindingTrimming(username));
         return map;
     }
 
@@ -699,6 +740,22 @@
                 glassOptimizeMapper.deleteOptimizeHeatDetail(projectNumber);
                 glassOptimizeMapper.deleteOptimizeHeatLayout(projectNumber);
                 glassOptimizeMapper.updateProjectTemperingStateMp(projectNumber, states);
+                Map<String, Object> temperingState = glassOptimizeMapper.getProjectState(projectNumber);
+
+                if (temperingState != null && temperingState.containsKey("optimize_state")) {
+                    Object optimizeStateObj = temperingState.get("optimize_state");
+                    if (optimizeStateObj != null) {
+                        try {
+                            int optimizeState = Integer.parseInt(optimizeStateObj.toString());
+                            if (optimizeState == 1) {
+                                glassOptimizeMapper.updateProjectTemperingId(projectNumber);
+                            }
+                        } catch (NumberFormatException e) {
+                            // 澶勭悊杞崲寮傚父锛岃褰曟棩蹇楁垨閲囧彇鍏朵粬閫傚綋鎺柦
+                            System.err.println("瑙f瀽 optimize_state 澶辫触: " + e.getMessage());
+                        }
+                    }
+                }
             }
             //鎾ら攢浼樺寲鎺掔増
             else if(code==2){
@@ -720,7 +777,24 @@
             }
             //鐢熶骇涓嶅彲瑙�
             else if(code==4){
-                glassOptimizeMapper.updateProjectStateMp(projectNumber, state);
+                Map<String, Object> cancelResult = issuingCancelProject(projectNumber);
+                // 鑾峰彇杩斿洖缁撴灉涓殑data瀛楁
+                Map<String, Object> responseData = (Map<String, Object>) cancelResult.get("data");
+                // 妫�鏌ュ搷搴斾腑鐨刢ode瀛楁锛屽彧鏈夊綋code涓�200鎴�202鏃舵墠鍏佽鏇存柊鐘舵��
+                if (responseData != null && responseData.containsKey("code")) {
+                    Object responseCode = responseData.get("code");
+                    if (responseCode.equals(200) || responseCode.equals(202)) {
+                        glassOptimizeMapper.updateProjectStateMp(projectNumber, state);
+                    } else if (responseCode.equals(201)) {
+                        // 褰撹繑鍥�201鏃讹紝鎶涘嚭鑷畾涔夊紓甯告垨杩斿洖閿欒淇℃伅
+                        throw new RuntimeException(responseData.get("message").toString());
+                    } else {
+                        return false;
+                    }
+                } else {
+                    return false;
+                }
+
             }
             //鍒濆鍖栧伐绋�
             else if(code==5){
@@ -847,68 +921,68 @@
             int state2 = 0;
             StringBuilder processId= new StringBuilder();
             List<FlowCard> flowCardList = JSONArray.parseArray(JSONObject.toJSONString(object.get("projectdetail")), FlowCard.class);
-            if (!flowCardList.isEmpty()) {
-                if(projectType.equals("2")){
-                    deleteProject(projectId,2);
+            if(projectType.equals("2")){
+                deleteProject(projectId,2);
+            }
+
+            // 鍒涘缓涓�涓槧灏勬潵瀛樺偍 (processId-technologyNumber) 缁勫悎鍒� rack 缂栧彿鐨勬槧灏�
+            Map<String, Integer> rackMap = new HashMap<>();
+            int rackCounter = 1;
+
+            // 濡傛灉涓虹┖娴佺▼鍗★紝鍒欏皢 type 璁剧疆涓� 1
+            if (flowCardList == null || flowCardList.isEmpty()) {
+                type = 1;
+            }
+            for (FlowCard flowCard : flowCardList) {
+                // 涓烘瘡涓敮涓�鐨� processId-technologyNumber 缁勫悎鍒嗛厤 rack 缂栧彿
+                String key = flowCard.getProcessId() + "-" + flowCard.getTechnologyNumber();
+                if (!rackMap.containsKey(key)) {
+                    rackMap.put(key, rackCounter++);
+                }
+                int rackValue = rackMap.get(key);
+
+                if(flowCard.getPatchState().equals(0)){
+                    state1=1;
+                    //缁欐祦绋嬪崱琛ㄦ坊鍔犲搴旂殑宸ョ▼鍙�
+                    Boolean a = glassOptimizeMapper.updateFlowCardProject(flowCard.getProcessId(),flowCard.getTechnologyNumber(),projectId);
+                    // 鏇存柊娴佺▼鍗$殑rack瀛楁
+                    glassOptimizeMapper.updateFlowCardRack(flowCard.getProcessId(), flowCard.getTechnologyNumber(), rackValue);
+                    area = glassOptimizeMapper.getSelectArea(flowCard.getProcessId(),flowCard.getTechnologyNumber()).doubleValue();
+                    sumArea = sumArea.add(BigDecimal.valueOf(area));
+                    sumQuantity +=flowCard.getQuantity();
+                    processId.append(flowCard.getProcessId()).append("-").append(flowCard.getTechnologyNumber()).append(";");
+                }else{
+                    state2=1;
+                    Boolean a=glassOptimizeMapper.updatePatchLogProject(flowCard.getProcessId(),flowCard.getTechnologyNumber(),projectId);
+                    area = glassOptimizeMapper.getSelectAreaPatchLog(flowCard.getProcessId(),flowCard.getTechnologyNumber()).doubleValue();
+                    sumArea = sumArea.add(BigDecimal.valueOf(area));
+                    sumQuantity +=flowCard.getQuantity();
+                    processId.append(flowCard.getProcessId()).append("-").append(flowCard.getTechnologyNumber()).append(";");
                 }
 
-                // 鍒涘缓涓�涓槧灏勬潵瀛樺偍 (processId-technologyNumber) 缁勫悎鍒� rack 缂栧彿鐨勬槧灏�
-                Map<String, Integer> rackMap = new HashMap<>();
-                int rackCounter = 1;
+            }
+            if(state1==1&&state2==0){
+                type=1;
+            }else if(state1==1&&state2==1){
+                type=2;
+            }
 
-                for (FlowCard flowCard : flowCardList) {
-                    // 涓烘瘡涓敮涓�鐨� processId-technologyNumber 缁勫悎鍒嗛厤 rack 缂栧彿
-                    String key = flowCard.getProcessId() + "-" + flowCard.getTechnologyNumber();
-                    if (!rackMap.containsKey(key)) {
-                        rackMap.put(key, rackCounter++);
-                    }
-                    int rackValue = rackMap.get(key);
-
-                    if(flowCard.getPatchState().equals(0)){
-                        state1=1;
-                        //缁欐祦绋嬪崱琛ㄦ坊鍔犲搴旂殑宸ョ▼鍙�
-                        Boolean a = glassOptimizeMapper.updateFlowCardProject(flowCard.getProcessId(),flowCard.getTechnologyNumber(),projectId);
-                        // 鏇存柊娴佺▼鍗$殑rack瀛楁
-                        glassOptimizeMapper.updateFlowCardRack(flowCard.getProcessId(), flowCard.getTechnologyNumber(), rackValue);
-                        area = glassOptimizeMapper.getSelectArea(flowCard.getProcessId(),flowCard.getTechnologyNumber()).doubleValue();
-                        sumArea = sumArea.add(BigDecimal.valueOf(area));
-                        sumQuantity +=flowCard.getQuantity();
-                        processId.append(flowCard.getProcessId()).append("-").append(flowCard.getTechnologyNumber()).append(";");
-                    }else{
-                        state2=1;
-                        Boolean a=glassOptimizeMapper.updatePatchLogProject(flowCard.getProcessId(),flowCard.getTechnologyNumber(),projectId);
-                        area = glassOptimizeMapper.getSelectAreaPatchLog(flowCard.getProcessId(),flowCard.getTechnologyNumber()).doubleValue();
-                        sumArea = sumArea.add(BigDecimal.valueOf(area));
-                        sumQuantity +=flowCard.getQuantity();
-                        processId.append(flowCard.getProcessId()).append("-").append(flowCard.getTechnologyNumber()).append(";");
-                    }
-
-                }
-                if(state1==1&&state2==0){
-                    type=1;
-                }else if(state1==1&&state2==1){
-                    type=2;
-                }
-                int index = optionVal.indexOf("mm");
-                // 鑾峰彇 "mm" 鍓嶉潰鐨勯儴鍒�
-                String glass_thickness = optionVal.substring(0, index);
-                // 鑾峰彇 "mm" 鍚庨潰鐨勯儴鍒�
-                String glass_type = optionVal.substring(index + 2);
-                if(projectType.equals("2")){
-                    glassOptimizeMapper.updateProjectMp(projectId,projectNmae,glass_thickness,glass_type,sumQuantity,sumArea.doubleValue(),userName,
+            int index = optionVal.indexOf("mm");
+            // 鑾峰彇 "mm" 鍓嶉潰鐨勯儴鍒�
+            String glass_thickness = optionVal.substring(0, index);
+            // 鑾峰彇 "mm" 鍚庨潰鐨勯儴鍒�
+            String glass_type = optionVal.substring(index + 2);
+            if(projectType.equals("2")){
+                glassOptimizeMapper.updateProjectMp(projectId,projectNmae,glass_thickness,glass_type,sumQuantity,sumArea.doubleValue(),userName,
+                        flowCardList.size(), String.valueOf(processId),type);
+            }else{
+                if(glassOptimizeMapper.selectProjectCount(projectId)==null){
+                    glassOptimizeMapper.addProjectMp(projectId,projectNmae,glass_thickness,glass_type,sumQuantity,sumArea.doubleValue(),userName,
                             flowCardList.size(), String.valueOf(processId),type);
                 }else{
-                    if(glassOptimizeMapper.selectProjectCount(projectId)==null){
-                        glassOptimizeMapper.addProjectMp(projectId,projectNmae,glass_thickness,glass_type,sumQuantity,sumArea.doubleValue(),userName,
-                                flowCardList.size(), String.valueOf(processId),type);
-                    }else{
-                        TransactionAspectSupport.currentTransactionStatus().rollbackToSavepoint(savePoint);
-                        return "false1";
-                    }
+                    TransactionAspectSupport.currentTransactionStatus().rollbackToSavepoint(savePoint);
+                    return "false1";
                 }
-            }else {
-                return "false2";
-
             }
         } catch (Exception e) {
             TransactionAspectSupport.currentTransactionStatus().rollbackToSavepoint(savePoint);
@@ -943,11 +1017,30 @@
             json = object.get("json").toString();
         }
         if(type.equals("閽㈠寲")){
-            glassOptimizeMapper.updateOptimizeConfig(json,1,username);
+            String existingConfig = glassOptimizeMapper.selectConfigByUserAndType(username, 1);
+            if (existingConfig == null) {
+                String configName = "閽㈠寲鎺ㄨ崘";
+                glassOptimizeMapper.insertOptimizeConfig(json,1,username,configName);
+            }else {
+                glassOptimizeMapper.updateOptimizeConfig(json,1,username);
+            }
         } else if (type.equals("淇竟")) {
-            glassOptimizeMapper.updateOptimizeConfig(json,5,username);
+            String existingConfig = glassOptimizeMapper.selectConfigByUserAndType(username, 5);
+            if (existingConfig == null) {
+                String configName = "淇竟閰嶇疆";
+                glassOptimizeMapper.insertOptimizeConfig(json,5,username,configName);
+            }else {
+                glassOptimizeMapper.updateOptimizeConfig(json,5,username);
+            }
         }else if (type.equals("纾ㄩ噺")) {
-            glassOptimizeMapper.updateOptimizeConfig(json,4,username);
+            String existingConfig = glassOptimizeMapper.selectConfigByUserAndType(username, 4);
+            if (existingConfig == null) {
+                String configName = "纾ㄩ噺閰嶇疆";
+                glassOptimizeMapper.insertOptimizeConfig(json,4,username,configName);
+            }else{
+                glassOptimizeMapper.updateOptimizeConfig(json,4,username);
+            }
+
         }
         return true;
 
@@ -1157,8 +1250,9 @@
     public Boolean issuingProjects(String projectNo) throws JsonProcessingException {
         boolean  saveState=false;
         try {
+            System.out.println(mesIp);
             // 1. 鍒涘缓URL瀵硅薄
-            URL url = new URL("http://localhost:88/api/loadGlass/engineering/importEngineer");
+            URL url = new URL("http://" + mesIp + ":88/api/loadGlass/engineering/importEngineer");
 
             // 2. 鎵撳紑杩炴帴
             HttpURLConnection conn = (HttpURLConnection) url.openConnection();
@@ -1245,13 +1339,58 @@
 
     public Map<String, Object> getMaterialInfoSv(String processId) {
         Map<String, Object> map = new HashMap<>();
-        map.put("materialList", glassOptimizeMapper.getMaterialInfoSv(processId));
+//        List<Map<String, Object>> materialList = glassOptimizeMapper.getMaterialInfoSv(processId);
+        List<Map<String, Object>> layoutSet = glassOptimizeMapper.getLayoutSetSv(processId);
+
+//        // 鍒涘缓涓�涓狹ap鏉ュ瓨鍌ㄦ瘡涓猻tock_code鐨勬�婚潰绉�
+//        Map<String, Double> stockCodeAreaMap = new HashMap<>();
+//
+//        // 閬嶅巻layoutSet璁$畻姣忎釜stock_code鐨勬�婚潰绉�(闈㈢Н*浣跨敤鐜�)
+//        for (Map<String, Object> layout : layoutSet) {
+//            Object stockCodeObj = layout.get("stock_code");
+//            Object widthObj = layout.get("width");
+//            Object heightObj = layout.get("height");
+//            Object usageRateObj = layout.get("usage_rate");
+//
+//            if (stockCodeObj != null && widthObj != null && heightObj != null && usageRateObj != null) {
+//                try {
+//                    String stockCode = stockCodeObj.toString();
+//                    double width = Double.parseDouble(widthObj.toString());
+//                    double height = Double.parseDouble(heightObj.toString());
+//                    double usageRate = Double.parseDouble(usageRateObj.toString());
+//
+//                    // 璁$畻鍗曟潯鏁版嵁鐨勯潰绉�(骞虫柟绫�)
+//                    double area = (width * height * usageRate) / 1000000.0;
+//
+//                    // 绱姞鍒板搴攕tock_code鐨勬�婚潰绉�
+//                    stockCodeAreaMap.put(stockCode, stockCodeAreaMap.getOrDefault(stockCode, 0.0) + area);
+//                } catch (NumberFormatException e) {
+//                    System.err.println("鏁版嵁杞崲閿欒: " + e.getMessage());
+//                }
+//            }
+//        }
+//
+//        // 灏嗚绠楀嚭鐨勬�婚潰绉坊鍔犲埌materialList涓搴旂殑鐗╂枡鏁版嵁
+//        for (Map<String, Object> material : materialList) {
+//            Object stockCodeObj = material.get("code");
+//            if (stockCodeObj != null) {
+//                String stockCode = stockCodeObj.toString();
+//                if (stockCodeAreaMap.containsKey(stockCode)) {
+//                    material.put("totalArea", stockCodeAreaMap.get(stockCode));
+//                }
+//            }
+//        }
+
+        map.put("materialList", layoutSet);
         return map;
     }
+
 
     public Map<String, Object> getProductListSv(String processId) {
         Map<String, Object> productMap = new HashMap<>();
         List<Map<String, Object>> productInfo = glassOptimizeMapper.selectProjectList(processId);
+        List<Map<String, Object>> tempProductInfo = glassOptimizeMapper.selectTempProject(processId);
+        productInfo.addAll(tempProductInfo);
         productMap.put("productInfo", productInfo);
         Map<String, Object> map = new HashMap<>();
 
@@ -1259,7 +1398,7 @@
             // 鎸夌収 processCard 鍒嗙粍
             Map<String, List<Map<String, Object>>> groupedByProcessCard = new HashMap<>();
             for (Map<String, Object> item : productInfo) {
-                String processCard = (String) item.get("processCard");
+                String processCard = String.valueOf(item.get("processCard"));
                 if (processCard != null) {
                     groupedByProcessCard.computeIfAbsent(processCard, k -> new ArrayList<>()).add(item);
                 }
@@ -1341,4 +1480,609 @@
     }
 
 
+    public Map<String, Object>  getProjectState(String projectNo) {
+        Map<String, Object> map = new HashMap<>();
+        map.put("data", glassOptimizeMapper.getProjectState(projectNo));
+        return map;
+    }
+
+    public Map<String, Object> issuingCancelProject(String projectNo){
+        Map<String, Object> result = new HashMap<>();
+        Map<String, Object> responseData = new HashMap<>();
+
+        try {
+            // 1. 鍒涘缓URL瀵硅薄
+            URL url = new URL("http://" + mesIp + ":88/api/loadGlass/engineering/optimizeCancelTask");
+//            URL url = new URL("http://localhost:88/api/loadGlass/engineering/optimizeCancelTask");
+
+
+            // 2. 鎵撳紑杩炴帴
+            HttpURLConnection conn = (HttpURLConnection) url.openConnection();
+            conn.setRequestMethod("POST");
+            conn.setRequestProperty("Content-Type", "application/json");
+            conn.setRequestProperty("Accept", "application/json");
+            conn.setDoOutput(true);
+
+            // 3. 鍑嗗璇锋眰浣� - 灏唒rojectNo杞崲涓篹ngineerId鏍煎紡
+            String engineerId = projectNo;
+            // 濡傛灉浼犲叆鐨勬槸JSON瀛楃涓诧紝闇�瑕佹彁鍙栫湡姝g殑projectNo鍊�
+            if (projectNo.startsWith("{") && projectNo.contains("\"projectNo\"")) {
+                try {
+                    JSONObject jsonObject = JSONObject.parseObject(projectNo);
+                    engineerId = jsonObject.getString("projectNo");
+                } catch (Exception e) {
+                    // 瑙f瀽澶辫触鏃朵娇鐢ㄥ師濮嬪��
+                    System.err.println("瑙f瀽projectNo JSON澶辫触: " + e.getMessage());
+                }
+            }
+
+            // 鏋勫缓鏂扮殑JSON璇锋眰浣擄紝浣跨敤engineerId瀛楁
+            String jsonInputString = "{\"engineerId\":\"" + engineerId + "\"}";
+            System.out.println("engineerId: " + engineerId);
+            System.out.println("Request: " + jsonInputString);
+
+            //鍙戦�佽姹�
+            try(OutputStream os = conn.getOutputStream()) {
+                byte[] input = jsonInputString.getBytes(StandardCharsets.UTF_8);
+                os.write(input, 0, input.length);
+            }
+
+            // 鑾峰彇鍝嶅簲
+            try(BufferedReader br = new BufferedReader(
+                    new InputStreamReader(conn.getInputStream(), StandardCharsets.UTF_8))) {
+                StringBuilder response = new StringBuilder();
+                String responseLine;
+                while ((responseLine = br.readLine()) != null) {
+                    response.append(responseLine.trim());
+                }
+                String fullResponse = response.toString();
+                System.out.println("Response: " + fullResponse);
+
+                // 鐩存帴灏嗗搷搴斿唴瀹硅В鏋愪负Map
+                responseData = JSONObject.parseObject(fullResponse, Map.class);
+            }
+
+            //鍏抽棴杩炴帴
+            conn.disconnect();
+        } catch (Exception e) {
+            e.printStackTrace();
+            // 寮傚父鎯呭喌涓嬪皢寮傚父淇℃伅鏀惧叆data
+            responseData.put("error", e.getMessage());
+        }
+
+        // 鏋勯�犳渶缁堣繑鍥炵粨鏋�
+        result.put("data", responseData);
+
+        return result;
+    }
+
+
+    public void processExternalOptimizeRequest(MesCalculateDTO mesCalculateDTO){
+        // 浣跨敤鍙嶅皠灏嗗璞¤浆鎹负 Map锛屼娇鐢� Java 瀛楁鍚�
+        List<Map<String, Object>> materialDetailList = new ArrayList<>();
+        if (mesCalculateDTO.getEngineeringRawQueueList() != null) {
+            for (MesCalculateDTO.EngineeringRawQueue materialDetail : mesCalculateDTO.getEngineeringRawQueueList()) {
+                Map<String, Object> materialMap = objectToMapUsingFields(materialDetail);
+                materialDetailList.add(materialMap);
+            }
+        }
+
+        List<Map<String, Object>> glassDetailList = new ArrayList<>();
+        if (mesCalculateDTO.getGlassInfoList() != null) {
+            for (MesCalculateDTO.GlassInfo glassDetail : mesCalculateDTO.getGlassInfoList()) {
+                Map<String, Object> glassMap = objectToMapUsingFields(glassDetail);
+                glassDetailList.add(glassMap);
+            }
+        }
+
+        List<Map<String, Object>> glassDamageList = new ArrayList<>();
+        if (mesCalculateDTO.getDamageList() != null) {
+            for (MesCalculateDTO.DamageList damageInfo : mesCalculateDTO.getDamageList()) {
+                Map<String, Object> damageMap = objectToMapUsingFields(damageInfo);
+                glassDamageList.add(damageMap);
+            }
+        }
+
+        List<Map<String, Object>> glassDamageTempList = new ArrayList<>();
+        if (mesCalculateDTO.getDamageList() != null) {
+            for (MesCalculateDTO.DamageList damageInfo : mesCalculateDTO.getDamageList()) {
+                Map<String, Object> damageMap = objectToMapUsingFields(damageInfo);
+                // 鍒涘缓鏂扮殑Map鍙繚鐣檊lassId瀛楁骞舵坊鍔爎eportState瀛楁
+                Map<String, Object> filteredDamageMap = new HashMap<>();
+                if (damageMap.containsKey("glassId")) {
+                    filteredDamageMap.put("glassId", damageMap.get("glassId"));
+                }
+                filteredDamageMap.put("reportState", 10);
+                glassDamageTempList.add(filteredDamageMap);
+            }
+        }
+
+        String projectNo = mesCalculateDTO.getEngineerId();
+        System.out.println("projectNo: " + projectNo);
+
+        for (Map<String, Object> materialDetail : materialDetailList) {
+            Object stockId = materialDetail.get("rawSequence");
+            Map<String, Object> trimInfo = glassOptimizeMapper.getTrimInfo(projectNo, stockId);
+            if (trimInfo != null) {
+                materialDetail.putAll(trimInfo);
+            }
+        }
+
+        Map<String, Object> glassOptimaizeMap = new HashMap<>();
+        Map<String, Object> optimizeProperty = glassOptimizeMapper.getGlassType(projectNo);
+
+        glassOptimaizeMap.put("requestSource", "ERP");
+        glassOptimaizeMap.put("usageRate", mesCalculateDTO.getUsageRate());
+        glassOptimaizeMap.put("optimizeProperty", optimizeProperty);
+        glassOptimaizeMap.put("engineeringRawQueueList", materialDetailList);
+        glassOptimaizeMap.put("glassInfoList", glassDetailList);
+
+        try {
+            ObjectMapper objectMapper = new ObjectMapper();
+
+            String glassDamageListJson = objectMapper.writeValueAsString(glassDamageList);
+            System.out.println("damageList JSON: " + glassDamageListJson);
+
+            String glassDamageTempListJson = objectMapper.writeValueAsString(glassDamageTempList);
+            System.out.println("glassDamageTempListJson: " + glassDamageTempListJson);
+
+            String optimizeJsonString = objectMapper.writeValueAsString(glassOptimaizeMap);
+            System.out.println("glassTypeMap JSON: " + optimizeJsonString);
+
+            // 鑾峰彇骞惰緭鍑哄姩鎬佷紭鍖栬繑鍥炵粨鏋�
+            String optimizeResult = callDynamicOptimizeApi(optimizeJsonString);
+            System.out.println("鍔ㄦ�佷紭鍖栬繑鍥炵粨鏋�: " + optimizeResult);
+
+            // 灏嗙粨鏋滆浆鎹负JSON鏍煎紡
+            Object optimaizeResultJson = null;
+            try {
+                // 灏濊瘯瑙f瀽涓篔SON瀵硅薄
+                optimaizeResultJson = objectMapper.readValue(optimizeResult, Object.class);
+            } catch (Exception e) {
+                // 濡傛灉涓嶆槸鏈夋晥鐨凧SON瀛楃涓诧紝鍒涘缓涓�涓寘鍚師濮嬪瓧绗︿覆鐨凪ap
+                Map<String, String> errorResult = new HashMap<>();
+                errorResult.put("result", optimizeResult);
+                optimaizeResultJson = errorResult;
+            }
+
+            // 杈撳嚭JSON鏍煎紡鐨勭粨鏋�
+            String jsonOptimizeResult = objectMapper.writeValueAsString(optimaizeResultJson);
+            System.out.println("鍔ㄦ�佷紭鍖栬繑鍥炵粨鏋淛SON鏍煎紡: " + jsonOptimizeResult);
+
+            // 璋冪敤issuingDamageDynamicProjects鎺ュ彛
+            Boolean MESResult = issuingDamageDynamicProjects(projectNo, glassDamageTempList);
+            System.out.println("MES杩斿洖缁撴灉: " + MESResult);
+
+
+            // 妫�鏌ssuingDamageDynamicProjects鎺ュ彛璋冪敤缁撴灉锛屽鏋滃け璐ュ垯鍋滄鍚庣画鎿嶄綔
+            if (!MESResult) {
+                System.out.println("issuingDamageDynamicProjects鎺ュ彛璋冪敤澶辫触锛屽仠姝㈠悗缁搷浣�");
+                return;
+            }
+
+            // 璋冪敤cutFiles鎺ュ彛
+            Boolean cutFileResult = callCutFilesApi(jsonOptimizeResult);
+            System.out.println("璋冪敤cutFiles鎺ュ彛杩斿洖缁撴灉: " + cutFileResult);
+
+            // 妫�鏌utFiles鎺ュ彛璋冪敤缁撴灉锛屽鏋滃け璐ュ垯鍋滄鍚庣画鎿嶄綔
+            if (!cutFileResult) {
+                System.out.println("cutFiles鎺ュ彛璋冪敤澶辫触锛屽仠姝㈠悗缁搷浣�");
+                return;
+            }
+
+            // 璋冪敤issuingDynamicProjects鎺ュ彛
+            Boolean MESTwiceResult = issuingDynamicProjects(projectNo);
+            System.out.println("MES浜屾杩斿洖缁撴灉: " + MESTwiceResult);
+
+            // 妫�鏌ssuingDynamicProjects鎺ュ彛璋冪敤缁撴灉锛屽鏋滃け璐ュ垯鍋滄鍚庣画鎿嶄綔
+            if (!MESTwiceResult) {
+                System.out.println("issuingDynamicProjects鎺ュ彛璋冪敤澶辫触锛屽仠姝㈠悗缁搷浣�");
+            }
+
+        } catch (JsonProcessingException e) {
+            System.err.println("杞崲JSON澶辫触: " + e.getMessage());
+        }
+    }
+
+
+
+
+    // 浣跨敤鍙嶅皠灏嗗璞¤浆鎹负 Map锛屼娇鐢� Java 瀛楁鍚�
+    private Map<String, Object> objectToMapUsingFields(Object obj) {
+        Map<String, Object> map = new HashMap<>();
+        if (obj == null) return map;
+
+        Class<?> clazz = obj.getClass();
+        Field[] fields = clazz.getDeclaredFields();
+
+        for (Field field : fields) {
+            try {
+                field.setAccessible(true);
+                Object value = field.get(obj);
+                // 浣跨敤 Java 瀛楁鍚嶄綔涓� key
+                map.put(field.getName(), value);
+            } catch (IllegalAccessException e) {
+                // 璁板綍鎴栧鐞嗗紓甯�
+                System.err.println("璁块棶瀛楁澶辫触: " + field.getName() + ", 閿欒: " + e.getMessage());
+            }
+        }
+        return map;
+    }
+
+    private String callDynamicOptimizeApi(String jsonData) {
+        try {
+            URL url = new URL("http://" + mesIp + ":8078/api/dynamicOptimize");
+
+            HttpURLConnection conn = (HttpURLConnection) url.openConnection();
+
+            // 璁剧疆璇锋眰鏂规硶
+            conn.setRequestMethod("POST");
+
+            // 璁剧疆璇锋眰澶�
+            conn.setRequestProperty("Content-Type", "application/json; charset=UTF-8");
+            conn.setRequestProperty("Accept", "application/json");
+
+            // 鍏佽杈撳嚭
+            conn.setDoOutput(true);
+
+            // 璁剧疆瓒呮椂鏃堕棿
+            conn.setConnectTimeout(10000); // 10绉掕繛鎺ヨ秴鏃�
+            conn.setReadTimeout(30000);    // 30绉掕鍙栬秴鏃�
+
+            // 鍙戦�丣SON鏁版嵁
+            try (OutputStream os = conn.getOutputStream()) {
+                byte[] input = jsonData.getBytes(StandardCharsets.UTF_8);
+                os.write(input, 0, input.length);
+            }
+
+            // 璇诲彇鍝嶅簲
+            StringBuilder response = new StringBuilder();
+            try (BufferedReader br = new BufferedReader(
+                    new InputStreamReader(conn.getInputStream(), StandardCharsets.UTF_8))) {
+                String responseLine;
+                while ((responseLine = br.readLine()) != null) {
+                    response.append(responseLine.trim());
+                }
+            }
+
+            String responseResult = response.toString();
+            System.out.println("浼樺寲杞欢鍝嶅簲缁撴灉: " + responseResult);
+            // 鏂紑杩炴帴
+            conn.disconnect();
+
+            ObjectMapper objectMapper = new ObjectMapper();
+            // 鍚敤绫诲瀷杞崲鍔熻兘锛屽厑璁稿皢娴偣鏁拌浆鎹负鏁存暟
+            objectMapper.configure(DeserializationFeature.ACCEPT_FLOAT_AS_INT, true);
+            Map<String, Object> responseMap = objectMapper.readValue(responseResult, Map.class);
+
+            // 妫�鏌ode鏄惁涓�200
+            Object codeObj = responseMap.get("code");
+            int code = -1;
+            if (codeObj instanceof Integer) {
+                code = (Integer) codeObj;
+            } else if (codeObj instanceof String) {
+                try {
+                    code = Integer.parseInt((String) codeObj);
+                } catch (NumberFormatException e) {
+                    System.err.println("鏃犳硶瑙f瀽code瀛楁: " + codeObj);
+                }
+            }
+
+            if (code == 200) {
+                // 璁剧疆鍥炴粴鐐癸紝鐢ㄤ簬浜嬪姟澶勭悊
+                Object savePoint = TransactionAspectSupport.currentTransactionStatus().createSavepoint();
+                try {
+                    // 杩斿洖data瀛楁鐨勫唴瀹逛綔涓篔SON瀛楃涓�
+                    Object dataObj = responseMap.get("data");
+                    if (dataObj != null) {
+                        // 纭繚 dataObj 鏄� Map 绫诲瀷骞堕獙璇� projectNo 瀛楁
+                        if (dataObj instanceof Map) {
+                            Map<String, Object> dataMap = (Map<String, Object>) dataObj;
+
+                            // 楠岃瘉 projectNo 鏄惁瀛樺湪
+                            Object projectNoObj = dataMap.get("projectNo");
+                            if (projectNoObj == null) {
+                                throw new RuntimeException("projectNo 涓嶈兘涓虹┖");
+                            }
+
+                            String projectNo = projectNoObj.toString();
+                            dataMap.put("projectNo", projectNo);
+
+                            // 鍒犻櫎宸插瓨鍦ㄧ殑鐩稿叧鏁版嵁
+                            glassOptimizeMapper.deleteOptimizeDynamicProject(projectNo);
+                            glassOptimizeMapper.deleteOptimizeDynamicLayout(projectNo);
+                            glassOptimizeMapper.deleteOptimizeDynamicDetail(projectNo);
+
+                            glassOptimizeMapper.insertDynamicProject(dataMap);
+
+                            // 澶勭悊 layouts 鏁扮粍骞舵彃鍏�
+                            Object layoutsObj = dataMap.get("layouts");
+                            if (layoutsObj instanceof List) {
+                                @SuppressWarnings("unchecked")
+                                List<Map<String, Object>> layouts = (List<Map<String, Object>>) layoutsObj;
+
+                                for (Map<String, Object> layout : layouts) {
+                                    // 涓烘瘡涓� layout 娣诲姞 projectNo
+                                    layout.put("projectNo", projectNo);
+
+                                    // 鑾峰彇褰撳墠 layout 鐨� glassDetails
+                                    Object glassDetailsObj = layout.get("glassDetails");
+                                    if (glassDetailsObj instanceof List) {
+                                        @SuppressWarnings("unchecked")
+                                        List<Map<String, Object>> glassDetails = (List<Map<String, Object>>) glassDetailsObj;
+
+                                        // 涓烘瘡涓� glassDetail 娣诲姞 projectNo 鍜屽鐞� glassPoint
+                                        for (Map<String, Object> detail : glassDetails) {
+                                            detail.put("projectNo", projectNo);
+
+
+//                                            // 澶勭悊 isRotate 涓� 1 鏃朵氦鎹� width 鍜� height 鐨勯�昏緫
+//                                            if (detail.containsKey("isRotate")) {
+//                                                Object isRotateObj = detail.get("isRotate");
+//                                                int isRotate = 0;
+//                                                if (isRotateObj instanceof Number) {
+//                                                    isRotate = ((Number) isRotateObj).intValue();
+//                                                } else if (isRotateObj instanceof String) {
+//                                                    isRotate = Integer.parseInt(isRotateObj.toString());
+//                                                }
+//
+//                                                if (isRotate == 1) {
+//                                                    // 浜ゆ崲 width 鍜� height
+//                                                    Object widthObj = detail.get("width");
+//                                                    Object heightObj = detail.get("height");
+//                                                    detail.put("width", heightObj);
+//                                                    detail.put("height", widthObj);
+//
+//
+//                                                }
+//                                            }
+
+                                            // 澶勭悊 glassPoint 瀛楁杞崲
+                                            if (detail.containsKey("glassPoint")) {
+                                                Object glassPointObj = detail.get("glassPoint");
+                                                if (glassPointObj != null) {
+                                                    try {
+                                                        // 濡傛灉 glassPointObj 宸茬粡鏄瓧绗︿覆锛屽垯涓嶉渶瑕佽浆鎹�
+                                                        if (!(glassPointObj instanceof String)) {
+                                                            // 灏嗗璞¤浆鎹负 JSON 瀛楃涓�
+                                                            String glassPointStr = objectMapper.writeValueAsString(glassPointObj);
+                                                            detail.put("glassPoint", glassPointStr);
+                                                        }
+                                                    } catch (Exception e) {
+                                                        // 濡傛灉杞崲澶辫触锛岃褰曢敊璇苟绉婚櫎璇ュ瓧娈�
+                                                        System.err.println("杞崲 glassPoint 澶辫触: " + e.getMessage());
+                                                        detail.remove("glassPoint");
+                                                    }
+                                                } else {
+                                                    // 濡傛灉 glassPointObj 涓� null锛岀Щ闄よ瀛楁
+                                                    detail.remove("glassPoint");
+                                                }
+                                            }
+                                        }
+
+                                        glassOptimizeMapper.insertDynamicDetail(glassDetails, projectNo);
+                                    }
+
+                                    // 鎻掑叆 layout 鍒� optimize_dynamic_layout 琛�
+                                    glassOptimizeMapper.insertDynamicLayout(layout);
+                                }
+                            }
+                        }
+                        return responseResult;
+                    } else {
+                        return "{}"; // 濡傛灉data瀛楁涓虹┖锛岃繑鍥炵┖JSON瀵硅薄
+                    }
+                } catch (Exception e) {
+                    // 鍙戠敓寮傚父鏃跺洖婊氫簨鍔�
+                    TransactionAspectSupport.currentTransactionStatus().rollbackToSavepoint(savePoint);
+                    throw e; // 閲嶆柊鎶涘嚭寮傚父
+                }
+            } else {
+                // 褰揷ode涓嶆槸200鏃讹紝杩斿洖閿欒淇℃伅
+                Object messageObj = responseMap.get("message");
+                String errorMessage = "鎺ュ彛杩斿洖閿欒鐮�: " + code;
+                if (messageObj != null) {
+                    errorMessage = messageObj.toString();
+                }
+                return errorMessage;
+            }
+
+        } catch (Exception e) {
+            System.err.println("璋冪敤鍔ㄦ�佷紭鍖栨帴鍙eけ璐�: " + e.getMessage());
+            e.printStackTrace();
+            return "璋冪敤鍔ㄦ�佷紭鍖栨帴鍙eけ璐�: " + e.getMessage();
+        }
+    }
+
+
+    public Boolean issuingDamageDynamicProjects(String projectNo, List<Map<String, Object>> glassDamageTempList){
+        boolean  saveState=false;
+        try {
+            System.out.println(mesIp);
+            // 1. 鍒涘缓URL瀵硅薄
+            URL url = new URL("http://" + mesIp + ":88/api/loadGlass/engineering/engineerOptimizeImport");
+
+            // 2. 鎵撳紑杩炴帴
+            HttpURLConnection conn = (HttpURLConnection) url.openConnection();
+            conn.setRequestMethod("POST");
+            conn.setRequestProperty("Content-Type", "application/json");
+            conn.setRequestProperty("Accept", "application/json");
+            conn.setDoOutput(true);
+
+            // 3. 鍑嗗璇锋眰浣�
+
+            // 鑾峰彇glassInfolList鏁版嵁
+            List<Map<String, Object>> glassInfolList = glassOptimizeMapper.selectOptimizeDynamicDetail(projectNo);
+
+            // 澶勭悊damageList锛屽glassInfolList涓瓨鍦ㄧ殑glassId璁剧疆reportState涓�10锛屼笉瀛樺湪鐨勮缃负1
+            List<Map<String, Object>> processedDamageList = new ArrayList<>();
+            Set<String> glassIdSet = new HashSet<>();
+
+            // 鏀堕泦glassInfolList涓殑鎵�鏈塯lassId
+            for (Map<String, Object> glassInfo : glassInfolList) {
+                if (glassInfo.containsKey("glassId") && glassInfo.get("glassId") != null) {
+                    glassIdSet.add(glassInfo.get("glassId").toString());
+                }
+            }
+
+            // 澶勭悊glassDamageTempList锛屾牴鎹甮lassId鏄惁鍦╣lassInfolList涓瓨鍦ㄦ潵璁剧疆reportState
+            for (Map<String, Object> damageItem : glassDamageTempList) {
+                if (damageItem.containsKey("glassId") && damageItem.get("glassId") != null) {
+                    String glassId = damageItem.get("glassId").toString();
+                    Map<String, Object> processedItem = new HashMap<>(damageItem);
+
+                    // 濡傛灉glassId鍦╣lassInfolList涓瓨鍦紝reportState淇濇寔涓�10锛屽惁鍒欐敼涓�6
+                    if (glassIdSet.contains(glassId)) {
+                        // glassId瀛樺湪锛屼繚鎸乺eportState涓�10锛堝凡鍦╣lassDamageTempList涓缃級
+                        processedItem.put("reportState", 10);
+                    } else {
+                        // glassId涓嶅瓨鍦紝灏唕eportState鏀逛负6
+                        processedItem.put("reportState", 6);
+                    }
+
+                    processedDamageList.add(processedItem);
+                }
+            }
+
+            Map<String, Object> optimizeProject=glassOptimizeMapper.selectOptimizeDynamicProject(projectNo);
+            optimizeProject.put("engineeringRawQueueList", glassOptimizeMapper.selectOptimizeDynamicLayout(projectNo));
+            optimizeProject.put("glassInfolList", glassOptimizeMapper.selectOptimizeDynamicDetail(projectNo));
+            optimizeProject.put("flowCardInfoList", glassOptimizeMapper.selectFlowCardDynamicInfoList(projectNo));
+            optimizeProject.put("damageList", processedDamageList);
+            ObjectMapper mapper = new ObjectMapper();
+            mapper.registerModule(new JavaTimeModule());
+            String jsonInputString = mapper.writeValueAsString(optimizeProject);
+            System.out.println("浼犵粰MES鐨勬暟鎹�"+ jsonInputString);
+
+            //鍙戦�佽姹�
+            try(OutputStream os = conn.getOutputStream()) {
+                byte[] input = jsonInputString.getBytes(StandardCharsets.UTF_8);
+                os.write(input, 0, input.length);
+            }
+
+            // 鑾峰彇鍝嶅簲
+            try(BufferedReader br = new BufferedReader(
+                    new InputStreamReader(conn.getInputStream(), StandardCharsets.UTF_8))) {
+                StringBuilder response = new StringBuilder();
+                String responseLine;
+                while ((responseLine = br.readLine()) != null) {
+                    response.append(responseLine.trim());
+                }
+                System.out.println("MES绗竴娆¤繑鍥炰俊鎭細 " + response.toString());
+                JSONObject obj = JSONObject.parseObject(response.toString());
+                if(obj.get("code").equals(200)&&obj.get("data").equals(true)){
+                    saveState=true;
+                }
+
+            }
+
+            //鍏抽棴杩炴帴
+            conn.disconnect();
+        } catch (Exception e) {
+            e.printStackTrace();
+            saveState= false;
+        }
+        return saveState;
+    }
+
+
+    public Boolean issuingDynamicProjects(String projectNo){
+        boolean  saveState=false;
+        try {
+            System.out.println(mesIp);
+            // 1. 鍒涘缓URL瀵硅薄
+            URL url = new URL("http://" + mesIp + ":88/api/loadGlass/engineering/importEngineer");
+
+            // 2. 鎵撳紑杩炴帴
+            HttpURLConnection conn = (HttpURLConnection) url.openConnection();
+            conn.setRequestMethod("POST");
+            conn.setRequestProperty("Content-Type", "application/json");
+            conn.setRequestProperty("Accept", "application/json");
+            conn.setDoOutput(true);
+
+            // 3. 鍑嗗璇锋眰浣�
+            Map<String, Object> optimizeProject=glassOptimizeMapper.selectOptimizeDynamicProject(projectNo);
+            optimizeProject.put("engineeringRawQueueList", glassOptimizeMapper.selectOptimizeDynamicLayout(projectNo));
+            optimizeProject.put("glassInfolList", glassOptimizeMapper.selectOptimizeDynamicDetail(projectNo));
+            optimizeProject.put("flowCardInfoList", glassOptimizeMapper.selectFlowCardDynamicInfoList(projectNo));
+            ObjectMapper mapper = new ObjectMapper();
+            mapper.registerModule(new JavaTimeModule());
+            String jsonInputString = mapper.writeValueAsString(optimizeProject);
+
+            //鍙戦�佽姹�
+            try(OutputStream os = conn.getOutputStream()) {
+                byte[] input = jsonInputString.getBytes(StandardCharsets.UTF_8);
+                os.write(input, 0, input.length);
+            }
+
+            // 鑾峰彇鍝嶅簲
+            try(BufferedReader br = new BufferedReader(
+                    new InputStreamReader(conn.getInputStream(), StandardCharsets.UTF_8))) {
+                StringBuilder response = new StringBuilder();
+                String responseLine;
+                while ((responseLine = br.readLine()) != null) {
+                    response.append(responseLine.trim());
+                }
+                System.out.println("MES绗簩娆¤繑鍥炰俊鎭�: " + response.toString());
+                JSONObject obj = JSONObject.parseObject(response.toString());
+                if(obj.get("code").equals(200)&&obj.get("data").equals(true)){
+                    saveState=true;
+                }
+
+            }
+
+            //鍏抽棴杩炴帴
+            conn.disconnect();
+        } catch (Exception e) {
+            e.printStackTrace();
+            saveState= false;
+        }
+        return saveState;
+    }
+
+
+    private Boolean callCutFilesApi(String jsonOptimizeResult) {
+        boolean saveState = false;
+        try {
+            System.out.println(mesIp);
+            // 1. 鍒涘缓URL瀵硅薄
+            URL url = new URL("http://" + mesIp + ":8078/api/resultToCutFiles");
+
+            // 2. 鎵撳紑杩炴帴
+            HttpURLConnection conn = (HttpURLConnection) url.openConnection();
+            conn.setRequestMethod("POST");
+            conn.setRequestProperty("Content-Type", "application/json");
+            conn.setRequestProperty("Accept", "application/json");
+            conn.setDoOutput(true);
+
+            // 3. 鍙戦�佽姹備綋
+            try(OutputStream os = conn.getOutputStream()) {
+                byte[] input = jsonOptimizeResult.getBytes(StandardCharsets.UTF_8);
+                os.write(input, 0, input.length);
+            }
+
+            // 鑾峰彇鍝嶅簲
+            try(BufferedReader br = new BufferedReader(
+                    new InputStreamReader(conn.getInputStream(), StandardCharsets.UTF_8))) {
+                StringBuilder response = new StringBuilder();
+                String responseLine;
+                while ((responseLine = br.readLine()) != null) {
+                    response.append(responseLine.trim());
+                }
+                System.out.println("淇濆瓨鍒囧壊鏂囦欢绔彛杩斿洖鏁版嵁: " + response.toString());
+                JSONObject obj = JSONObject.parseObject(response.toString());
+                if(obj.get("code").equals(200)){
+                    saveState = true;
+                }
+
+            }
+
+            //鍏抽棴杩炴帴
+            conn.disconnect();
+        } catch (Exception e) {
+            e.printStackTrace();
+            saveState = false;
+        }
+        return saveState;
+    }
 }

--
Gitblit v1.8.0