From f25bbbc769f14d18c39f11ba0e395a9f09431148 Mon Sep 17 00:00:00 2001 From: lty <876263681@qq.com> Date: 星期日, 11 五月 2025 12:13:06 +0800 Subject: [PATCH] #调试 --- src/main/java/com/zy/core/thread/SiemensDevpThread.java | 318 +++++++++++++++++++++++++++++----------------------- 1 files changed, 177 insertions(+), 141 deletions(-) diff --git a/src/main/java/com/zy/core/thread/SiemensDevpThread.java b/src/main/java/com/zy/core/thread/SiemensDevpThread.java index ca72822..2bf4d3a 100644 --- a/src/main/java/com/zy/core/thread/SiemensDevpThread.java +++ b/src/main/java/com/zy/core/thread/SiemensDevpThread.java @@ -28,10 +28,7 @@ import lombok.extern.slf4j.Slf4j; import java.text.MessageFormat; -import java.util.ArrayList; -import java.util.Date; -import java.util.List; -import java.util.Map; +import java.util.*; import java.util.concurrent.ConcurrentHashMap; /** @@ -71,12 +68,22 @@ add(401);add(402);add(403);add(404); }}; - public static final ArrayList<Integer> BarcodeList = new ArrayList<Integer>() {{ - add(1); add(2);add(3);add(4);add(5);add(6);add(7);add(8);add(9); + public static final ArrayList<Integer> BarcodeList1 = new ArrayList<Integer>() {{ + add(1); add(2);add(3);add(4);add(5); + }}; + + public static final ArrayList<Integer> BarcodeList2 = new ArrayList<Integer>() {{ + add(6);add(7);add(8);add(9); add(10); add(11); add(12); add(13); }}; - public static final ArrayList<Integer> staNosErrList = new ArrayList<Integer>() {{ - add(101); add(201); + public static final ArrayList<Integer> staNosErrList2 = new ArrayList<Integer>() {{ + add(101); add(104);add(106);add(108); + add(202);add(204);add(207);add(210); + }}; + + public static final ArrayList<Integer> staNosErrList1 = new ArrayList<Integer>() {{ + add(122); + add(222);add(224);add(227);add(230); }}; private Integer count=0; @@ -103,6 +110,17 @@ this.slave = slave; } + private ArrayList<Integer> getStaNoErr() { + switch (slave.getId()) { + case 1: + return staNosErrList1; + case 2: + return staNosErrList2; + default: + throw new CoolException("鏈嶅姟鍣ㄥ紓甯�"); + } + } + private ArrayList<Integer> getStaNo() { switch (slave.getId()) { case 1: @@ -111,6 +129,16 @@ return staNos2; default: throw new CoolException("鏈嶅姟鍣ㄥ紓甯�"); + } + } + private ArrayList<Integer> getBarcodeList() { + switch (slave.getId()) { + case 1: + return BarcodeList1; + case 2: + return BarcodeList2; + default: + throw new CoolException("鑾峰彇绔欑偣澶辫触锛�"); } } @@ -198,6 +226,20 @@ return result; } + public static int getOffsetFromSiteId(int siteId) { + if (siteId < 100 || siteId > 450) { + throw new IllegalArgumentException("siteId 瓒呭嚭鏈夋晥鑼冨洿: " + siteId); + } + return (siteId - 100) * 8; + } + + public static int getOffsetFromSiteId2(int siteId) { + if (siteId < 100 || siteId > 450) { + throw new IllegalArgumentException("siteId 瓒呭嚭鏈夋晥鑼冨洿: " + siteId); + } + return (siteId - 100) * 6; + } + /** * 璇诲彇鐘舵�� ====> 鏁村潡plc */ @@ -205,11 +247,12 @@ // // 鏇存柊鍏ュ嚭搴撴ā寮� // updateIoMode(); ArrayList<Integer> staNos = getStaNo(); + ArrayList<Integer> staNosErrList = getStaNoErr(); int staNoSize = staNos.size(); - OperateResultExOne<byte[]> result = siemensS7Net.Read("DB101.0", (short) (staNoSize*8)); - OperateResultExOne<byte[]> result200 = siemensS7Net.Read("DB101.800", (short) (staNoSize*8)); + OperateResultExOne<byte[]> result = siemensS7Net.Read("DB101.0", (short) (500 * 8)); + if (result.IsSuccess) { - for (int i = 0; i < staNoSize; i++) { + for(int i = 0 ; i<staNoSize;i++){ Integer siteId = staNos.get(i); // 绔欑偣缂栧彿 StaProtocol staProtocol = station.get(siteId); if (null == staProtocol) { @@ -218,19 +261,13 @@ station.put(siteId, staProtocol); } boolean[] status = null; - if(i < 24){ - staProtocol.setWorkNo(siemensS7Net.getByteTransform().TransInt32(result.Content, i*8)); // 宸ヤ綔鍙� + int offset = getOffsetFromSiteId(siteId);//鍙栦綑鑾峰緱瀵瑰簲db鍧楁暟鎹� - staProtocol.setStaNo(siemensS7Net.getByteTransform().TransInt16(result.Content, i*8 + 4)); // 鐩爣绔� + staProtocol.setWorkNo(siemensS7Net.getByteTransform().TransInt32(result.Content, offset)); // 宸ヤ綔鍙� - status = siemensS7Net.getByteTransform().TransBool(result.Content, i*8 + 6, 2); - }else { - staProtocol.setWorkNo(siemensS7Net.getByteTransform().TransInt32(result200.Content, (i-24)*8)); // 宸ヤ綔鍙� + staProtocol.setStaNo(siemensS7Net.getByteTransform().TransInt16(result.Content, offset+ 4)); // 鐩爣绔� - staProtocol.setStaNo(siemensS7Net.getByteTransform().TransInt16(result200.Content, (i-24)*8 + 4)); // 鐩爣绔� - - status = siemensS7Net.getByteTransform().TransBool(result200.Content, (i-24)*8 + 6, 2); - } + status = siemensS7Net.getByteTransform().TransBool(result.Content, offset+ 6, 2); staProtocol.setAutoing(status[0]); // 鑷姩 staProtocol.setLoading(status[1]); // 鏈夌墿 @@ -247,113 +284,114 @@ } } - //鏉$爜鎵弿鍣� - ArrayList<Integer> barcodeList = BarcodeList; - OperateResultExOne<byte[]> result2 = siemensS7Net.Read("DB101.1648", (short) (barcodeList.size() * 8)); - if (result2.IsSuccess) { - for (int i = 0; i < barcodeList.size(); i++) { - Integer barcodeId = barcodeList.get(i); - String barcode = siemensS7Net.getByteTransform().TransString(result2.Content,i*8,8, "UTF-8"); - BarcodeThread barcodeThread = (BarcodeThread) SlaveConnection.get(SlaveType.Barcode, barcodeId); - if(!Cools.isEmpty(barcodeThread) && !barcodeThread.getBarcode().equals(barcode)) { - barcodeThread.setBarcode(barcode); + //鏉$爜鎵弿鍣� + ArrayList<Integer> barcodeList = getBarcodeList(); + OperateResultExOne<byte[]> result2 = siemensS7Net.Read("DB101.2848", (short) (barcodeList.size() * 8)); + if (result2.IsSuccess) { + for (int i = 0; i < barcodeList.size(); i++) { + Integer barcodeId = barcodeList.get(i); + String barcode = siemensS7Net.getByteTransform().TransString(result2.Content, i * 8, 8, "UTF-8"); + BarcodeThread barcodeThread = (BarcodeThread) SlaveConnection.get(SlaveType.Barcode, barcodeId); + if (!Cools.isEmpty(barcodeThread) && !barcodeThread.getBarcode().equals(barcode)) { + barcodeThread.setBarcode(barcode); + } } } - } - //澶栧舰妫�娴� - ArrayList<Integer> staNoErrs = staNosErrList; - int staNoErrsSize = staNoErrs.size(); - OperateResultExOne<byte[]> resultErr = siemensS7Net.Read("DB101.1608", (short) (staNoErrsSize*8)); - if (resultErr.IsSuccess){ - for (int i = 0;i<2;i++){ - Integer siteId = staNoErrs.get(i); // 绔欑偣缂栧彿 - boolean[] status = siemensS7Net.getByteTransform().TransBool(resultErr.Content, i*4+2, 1); - StaProtocol staProtocol = station.get(siteId); - staProtocol.setFrontErr(status[0]); - staProtocol.setBackErr(status[1]); - staProtocol.setHighErr(status[2]); - staProtocol.setLeftErr(status[3]); - staProtocol.setRightErr(status[4]); - staProtocol.setWeightErr(status[5]); - staProtocol.setBarcodeErr(status[6]); - } - } - - //plc鏁呴殰 - OperateResultExOne<byte[]> resultErr2 = siemensS7Net.Read("DB101.1728", (short) (staNoSize*4)); - if (resultErr2.IsSuccess) { - for (int i = 0; i < staNoSize; i++) { - Integer siteId = staNos.get(i); // 绔欑偣缂栧彿 - boolean[] status = siemensS7Net.getByteTransform().TransBool(resultErr2.Content, i*4, 1); - StaProtocol staProtocol = station.get(siteId); - staProtocol.setBreakerErr(status[0]); - staProtocol.setInfraredErr(status[1]); - staProtocol.setOutTimeErr(status[2]); - staProtocol.setSeizeSeatErr(status[3]); - staProtocol.setWrkYgoodsN(status[4]); - staProtocol.setInverterErr(status[5]); - staProtocol.setContactErr(status[6]); - staProtocol.setUpcontactErr(status[7]); - - } - } - OperateResultExOne<byte[]> resultErr3 = siemensS7Net.Read("DB13.400", (short) 3); - if (resultErr3.IsSuccess) { - if (staError1 == null){ - staError1 = new StaError1(); - } - boolean[] status = siemensS7Net.getByteTransform().TransBool(resultErr3.Content, 0, 3); - staError1.setEMERGENCY_Stop_Core(status[0]); - staError1.setEMERGENCY_STOP1(status[1]); - staError1.setEMERGENCY_STOP2(status[2]); - staError1.setEMERGENCY_STOP3(status[3]); - staError1.setEMERGENCY_STOP4(status[4]); - - staError1.setDoor_EMERGENCY_STOP1(status[5]); - staError1.setDoor_EMERGENCY_STOP2(status[6]); - staError1.setDoor_EMERGENCY_STOP3(status[7]); - staError1.setDoor_EMERGENCY_STOP4(status[8]); - staError1.setDoor_EMERGENCY_STOP5(status[9]); - staError1.setDoor_EMERGENCY_STOP6(status[10]); - - staError1.setDoor_Open_Err1(status[11]); - staError1.setDoor_Open_Err1(status[12]); - staError1.setDoor_Open_Err1(status[13]); - staError1.setDoor_Open_Err1(status[14]); - staError1.setDoor_Open_Err1(status[15]); - staError1.setDoor_Open_Err1(status[16]); - - } - - - if (result.IsSuccess) { - - OutputQueue.DEVP.offer(MessageFormat.format("銆恵0}銆慬id:{1}] <<<<< 瀹炴椂鏁版嵁鏇存柊鎴愬姛",DateUtils.convert(new Date()), slave.getId())); - - // 鏍规嵁瀹炴椂淇℃伅鏇存柊鏁版嵁搴� - try { - List<BasDevp> basDevps = new ArrayList<>(); - for (Integer siteId : staNos) { + //澶栧舰妫�娴� + ArrayList<Integer> staNoErrs = staNosErrList; + int staNoErrsSize = staNoErrs.size(); + OperateResultExOne<byte[]> resultErr = siemensS7Net.Read("DB101.2808", (short) (staNoErrsSize * 4)); + if (resultErr.IsSuccess) { + for (int i = 0; i < staNoErrsSize; i++) { + Integer siteId = staNoErrs.get(i); // 绔欑偣缂栧彿 + boolean[] status = siemensS7Net.getByteTransform().TransBool(resultErr.Content, i * 4 + 2, 1); StaProtocol staProtocol = station.get(siteId); - basDevps.add(staProtocol.toSqlModel()); + staProtocol.setFrontErr(status[0]); + staProtocol.setBackErr(status[1]); + staProtocol.setHighErr(status[2]); + staProtocol.setLeftErr(status[3]); + staProtocol.setRightErr(status[4]); + staProtocol.setWeightErr(status[5]); + staProtocol.setBarcodeErr(status[6]); } - BasDevpService basDevpService = SpringContextUtil.getBean(BasDevpService.class); - //BasDevpService basDevpService = SpringUtils.getBean(BasDevpService.class); - if (null != basDevpService && !basDevpService.updateBatchById(basDevps)) { - throw new Exception("鏇存柊鏁版嵁搴撴暟鎹け璐�"); - } - } catch (Exception e) { - initSite(); - e.printStackTrace(); - OutputQueue.DEVP.offer(MessageFormat.format("銆恵0}銆戞洿鏂版暟鎹簱鏁版嵁澶辫触 ===>> [id:{1}] [ip:{2}] [port:{3}] [rack:{4}] [slot:{5}]", DateUtils.convert(new Date()), slave.getId(), slave.getIp(), slave.getPort(), slave.getRack(), slave.getSlot())); - News.error("SiemensDevp"+" - 3"+" - 鏇存柊鏁版嵁搴撴暟鎹け璐� ===>> [id:{}] [ip:{}] [port:{}] [rack:{}] [slot:{}]", slave.getId(), slave.getIp(), slave.getPort(), slave.getRack(), slave.getSlot()); } - } else { - OutputQueue.DEVP.offer(MessageFormat.format("銆恵0}銆戣鍙栬緭閫佺嚎plc鐘舵�佷俊鎭け璐� ===>> [id:{1}] [ip:{2}] [port:{3}] [rack:{4}] [slot:{5}]", DateUtils.convert(new Date()), slave.getId(), slave.getIp(), slave.getPort(), slave.getRack(), slave.getSlot())); +// //plc鏁呴殰 +// OperateResultExOne<byte[]> resultErr2 = siemensS7Net.Read("DB101.1728", (short) (staNoSize*4)); +// if (resultErr2.IsSuccess) { +// for (int i = 0; i < staNoSize; i++) { +// Integer siteId = staNos.get(i); // 绔欑偣缂栧彿 +// boolean[] status = siemensS7Net.getByteTransform().TransBool(resultErr2.Content, i*4, 1); +// StaProtocol staProtocol = station.get(siteId); +// staProtocol.setBreakerErr(status[0]); +// staProtocol.setInfraredErr(status[1]); +// staProtocol.setOutTimeErr(status[2]); +// staProtocol.setSeizeSeatErr(status[3]); +// staProtocol.setWrkYgoodsN(status[4]); +// staProtocol.setInverterErr(status[5]); +// staProtocol.setContactErr(status[6]); +// staProtocol.setUpcontactErr(status[7]); +// +// } +// } +// OperateResultExOne<byte[]> resultErr3 = siemensS7Net.Read("DB13.400", (short) 3); +// if (resultErr3.IsSuccess) { +// if (staError1 == null){ +// staError1 = new StaError1(); +// } +// boolean[] status = siemensS7Net.getByteTransform().TransBool(resultErr3.Content, 0, 3); +// staError1.setEMERGENCY_Stop_Core(status[0]); +// staError1.setEMERGENCY_STOP1(status[1]); +// staError1.setEMERGENCY_STOP2(status[2]); +// staError1.setEMERGENCY_STOP3(status[3]); +// staError1.setEMERGENCY_STOP4(status[4]); +// +// staError1.setDoor_EMERGENCY_STOP1(status[5]); +// staError1.setDoor_EMERGENCY_STOP2(status[6]); +// staError1.setDoor_EMERGENCY_STOP3(status[7]); +// staError1.setDoor_EMERGENCY_STOP4(status[8]); +// staError1.setDoor_EMERGENCY_STOP5(status[9]); +// staError1.setDoor_EMERGENCY_STOP6(status[10]); +// +// staError1.setDoor_Open_Err1(status[11]); +// staError1.setDoor_Open_Err1(status[12]); +// staError1.setDoor_Open_Err1(status[13]); +// staError1.setDoor_Open_Err1(status[14]); +// staError1.setDoor_Open_Err1(status[15]); +// staError1.setDoor_Open_Err1(status[16]); +// +// } + + + if (result.IsSuccess) { + + OutputQueue.DEVP.offer(MessageFormat.format("銆恵0}銆慬id:{1}] <<<<< 瀹炴椂鏁版嵁鏇存柊鎴愬姛", DateUtils.convert(new Date()), slave.getId())); + + // 鏍规嵁瀹炴椂淇℃伅鏇存柊鏁版嵁搴� + try { + List<BasDevp> basDevps = new ArrayList<>(); + for (Integer siteId : staNos) { + StaProtocol staProtocol = station.get(siteId); + basDevps.add(staProtocol.toSqlModel()); + } + BasDevpService basDevpService = SpringContextUtil.getBean(BasDevpService.class); + //BasDevpService basDevpService = SpringUtils.getBean(BasDevpService.class); + if (null != basDevpService && !basDevpService.updateBatchById(basDevps)) { + throw new Exception("鏇存柊鏁版嵁搴撴暟鎹け璐�"); + } + } catch (Exception e) { + initSite(); + e.printStackTrace(); + OutputQueue.DEVP.offer(MessageFormat.format("銆恵0}銆戞洿鏂版暟鎹簱鏁版嵁澶辫触 ===>> [id:{1}] [ip:{2}] [port:{3}] [rack:{4}] [slot:{5}]", DateUtils.convert(new Date()), slave.getId(), slave.getIp(), slave.getPort(), slave.getRack(), slave.getSlot())); + News.error("SiemensDevp" + " - 3" + " - 鏇存柊鏁版嵁搴撴暟鎹け璐� ===>> [id:{}] [ip:{}] [port:{}] [rack:{}] [slot:{}]", slave.getId(), slave.getIp(), slave.getPort(), slave.getRack(), slave.getSlot()); + } + + } else { + OutputQueue.DEVP.offer(MessageFormat.format("銆恵0}銆戣鍙栬緭閫佺嚎plc鐘舵�佷俊鎭け璐� ===>> [id:{1}] [ip:{2}] [port:{3}] [rack:{4}] [slot:{5}]", DateUtils.convert(new Date()), slave.getId(), slave.getIp(), slave.getPort(), slave.getRack(), slave.getSlot())); // log.error("璇诲彇杈撻�佺嚎plc鐘舵�佷俊鎭け璐� ===>> [id:{}] [ip:{}] [port:{}] [rack:{}] [slot:{}]", slave.getId(), slave.getIp(), slave.getPort(), slave.getRack(), slave.getSlot()); + } } - } + /** * 鍐欏叆 ID+鐩爣绔� =====> 鍗曠珯鐐瑰啓鍏� @@ -363,20 +401,17 @@ return; } ArrayList<Integer> staNos = getStaNo(); - int index = staNos.indexOf(staProtocol.getSiteId()); - - if(index >= 24){ - index = 76 + index; - } +// int index = staNos.indexOf(staProtocol.getSiteId()); + int offset = getOffsetFromSiteId2(staProtocol.getSiteId());//鍙栦綑鑾峰緱瀵瑰簲db鍧楁暟鎹� OperateResult write = null; OperateResult write1 = null; //浠诲姟涓嬪彂娆℃暟 int writeCount = 0; do { - write = siemensS7Net.Write("DB100." + index*6, staProtocol.getWorkNo()); // 宸ヤ綔鍙� + write = siemensS7Net.Write("DB100." + offset, staProtocol.getWorkNo()); // 宸ヤ綔鍙� Thread.sleep(200); - write1 = siemensS7Net.Write("DB100." + (index*6+4), staProtocol.getStaNo().shortValue()); // 鐩爣绔� + write1 = siemensS7Net.Write("DB100." + (offset+4), staProtocol.getStaNo().shortValue()); // 鐩爣绔� if(write.IsSuccess && write1.IsSuccess){ log.error("鍐欏叆杈撻�佺嚎鍛戒护鎴愬姛銆傝緭閫佺嚎plc缂栧彿={}锛岀珯鐐规暟鎹�={},鍐欏叆娆℃暟={}", slave.getId(), JSON.toJSON(staProtocol), writeCount); break; @@ -394,21 +429,22 @@ } OutputQueue.DEVP.offer(MessageFormat.format("銆恵0}銆戝啓鍏ヨ緭閫佺嚎绔欑偣鏁版嵁澶辫触銆傝緭閫佺嚎plc缂栧彿={1}锛岀珯鐐规暟鎹�={2}", slave.getId(), JSON.toJSON(staProtocol))); News.error("SiemensDevp"+" - 4"+" - 鍐欏叆杈撻�佺嚎绔欑偣鏁版嵁澶辫触銆傝緭閫佺嚎plc缂栧彿={}锛岀珯鐐规暟鎹�={}", slave.getId(), JSON.toJSON(staProtocol)); - } else { - //dang 101,201zhan xaifazhiling qingchu tiaoxingsaomaolide shuju shanchu - if (staProtocol.getSiteId()==101){ - BarcodeThread barcodeThread = (BarcodeThread) SlaveConnection.get(SlaveType.Barcode, 1); - log.info("qingchutiaoma,{}",barcodeThread.getBarcode()); - barcodeThread.clearBarcode(); - } - if (staProtocol.getSiteId()==201){ - BarcodeThread barcodeThread = (BarcodeThread) SlaveConnection.get(SlaveType.Barcode, 2); - log.info("qingchutiaoma,{}",barcodeThread.getBarcode()); - barcodeThread.clearBarcode(); - } - OutputQueue.DEVP.offer(MessageFormat.format("銆恵0}銆� 杈撻�佺嚎鍛戒护涓嬪彂 [id:{1}] >>>>> {2}", DateUtils.convert(new Date()), slave.getId(), JSON.toJSON(staProtocol))); - News.info("SiemensDevp"+" - 5"+" - 杈撻�佺嚎鍛戒护涓嬪彂 [id:{}] >>>>> 鍛戒护涓嬪彂锛� {}", slave.getId(), JSON.toJSON(staProtocol)); } +// else { +// //dang 101,201zhan xaifazhiling qingchu tiaoxingsaomaolide shuju shanchu +// if (staProtocol.getSiteId()==101){ +// BarcodeThread barcodeThread = (BarcodeThread) SlaveConnection.get(SlaveType.Barcode, 1); +// log.info("qingchutiaoma,{}",barcodeThread.getBarcode()); +// barcodeThread.clearBarcode(); +// } +// if (staProtocol.getSiteId()==201){ +// BarcodeThread barcodeThread = (BarcodeThread) SlaveConnection.get(SlaveType.Barcode, 2); +// log.info("qingchutiaoma,{}",barcodeThread.getBarcode()); +// barcodeThread.clearBarcode(); +// } +// OutputQueue.DEVP.offer(MessageFormat.format("銆恵0}銆� 杈撻�佺嚎鍛戒护涓嬪彂 [id:{1}] >>>>> {2}", DateUtils.convert(new Date()), slave.getId(), JSON.toJSON(staProtocol))); +// News.info("SiemensDevp"+" - 5"+" - 杈撻�佺嚎鍛戒护涓嬪彂 [id:{}] >>>>> 鍛戒护涓嬪彂锛� {}", slave.getId(), JSON.toJSON(staProtocol)); +// } } // 鏇存柊鍏ュ嚭搴撴ā寮� -- Gitblit v1.9.1