From 3edcf811c7a4b5dc8de9117d88d199b0d74e81a6 Mon Sep 17 00:00:00 2001
From: zhubaomin <zhubaomin>
Date: 星期五, 16 八月 2024 16:42:09 +0800
Subject: [PATCH] 2024-08-16 朱宝民 优化代码

---
 pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V1_0_0/parse/Cd_21_Down.java |   88 ++++++++++++++++++++++++++------------------
 1 files changed, 52 insertions(+), 36 deletions(-)

diff --git a/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V1_0_0/parse/Cd_21_Down.java b/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V1_0_0/parse/Cd_21_Down.java
index 3e518e0..4cf5ecc 100644
--- a/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V1_0_0/parse/Cd_21_Down.java
+++ b/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V1_0_0/parse/Cd_21_Down.java
@@ -1,11 +1,15 @@
 package com.dy.common.mw.protocol.p206V1_0_0.parse;
 
+import com.alibaba.fastjson2.JSON;
+import com.alibaba.fastjson2.JSONObject;
 import com.dy.common.mw.protocol.*;
 import com.dy.common.mw.protocol.p206V1_0_0.CodeV1_0_1;
 import com.dy.common.mw.protocol.p206V1_0_0.CommonV1_0_1;
 import com.dy.common.mw.protocol.p206V1_0_0.ParseParamsForDownV1_0_1;
 import com.dy.common.mw.protocol.p206V1_0_0.ProtocolConstantV206V1_0_0;
+import com.dy.common.mw.protocol.p206V1_0_0.downVos.Com21Vo;
 import com.dy.common.mw.protocol.p206V1_0_0.parse.global.GlCreate;
+import com.dy.common.mw.protocol.p206V202404.downVos.ComCd21Vo;
 import com.dy.common.util.ByteUtil;
 import com.dy.common.util.ByteUtilUnsigned;
 
@@ -52,57 +56,69 @@
      * @throws Exception 寮傚父
      */
     public byte[] doParse(ParseParamsForDownV1_0_1 para) throws Exception {
-        CommonV1_0_1 commonV1_0_1 = new CommonV1_0_1() ;
-        byte[] bytes ;
-        byte[] bsHead = new byte[ProtocolConstantV206V1_0_0.lenHead2Code] ;
-        byte index = 0 ;
-        bsHead[index] = ProtocolConstantV206V1_0_0.P_Head_Byte ;
-
-        index++ ;
-        bsHead[index] = 0 ;//甯ч暱搴�
-
-        index++ ;
-        bsHead[index] = ProtocolConstantV206V1_0_0.P_Head_Byte ;
-
-        index++ ;
-        bsHead[index] = commonV1_0_1.createCtrl((byte)0, (byte)0) ;
-
-        index++ ;
-        GlCreate.createRtuAddr(para.rtuAddr, bsHead, index);
-        index += 5 ;
-
-        ByteUtil.hex2Bytes(para.commandCode, bsHead, index) ;
-
-        /*
-        鍙傛暟鏍煎紡锛� ip1,ip2,ip3,ip4,port
-         */
-        if(para.param == null){
-            throw new Exception("鏈彁渚涘懡浠ゅ弬鏁版暟鎹紝涓嶈兘鏋勯�犲姛鑳界爜涓�" + para.commandCode + "鐨勪笅琛屽懡浠�") ;
+        if(para.param == null) {
+            throw new Exception("鍛戒护鍙傛暟涓簄ull") ;
         }else{
+            JSONObject obj = (JSONObject) para.param;
+            String json = obj.toJSONString();
+            Com21Vo cvo = JSON.parseObject(json, Com21Vo.class);
+            if(cvo == null){
+                throw new Exception("json杞珻om21Vo涓簄ull") ;
+            }
+            if(cvo.ip == null || cvo.ip.equals("")){
+                throw new Exception("IP涓嶈兘涓虹┖") ;
+            }
+            if(cvo.ip.length() > 15){
+                throw new Exception("IP鏈�澶ч暱搴︽槸15涓瓧绗�") ;
+            }
+            if(cvo.port < 0 || cvo.port > 65535){
+                throw new Exception("绔彛鍙峰繀椤绘槸0~65535鑼冨洿鍐呯殑鏁存暟") ;
+            }
+            CommonV1_0_1 commonV1_0_1 = new CommonV1_0_1() ;
+            byte[] bytes ;
+            byte[] bsHead = new byte[ProtocolConstantV206V1_0_0.lenHead2Code] ;
+            byte index = 0 ;
+            bsHead[index] = ProtocolConstantV206V1_0_0.P_Head_Byte ;
+
+            index++ ;
+            bsHead[index] = 0 ;//甯ч暱搴�
+
+            index++ ;
+            bsHead[index] = ProtocolConstantV206V1_0_0.P_Head_Byte ;
+
+            index++ ;
+            bsHead[index] = commonV1_0_1.createCtrl((byte)0, (byte)0) ;
+
+            index++ ;
+            GlCreate.createRtuAddr(para.rtuAddr, bsHead, index);
+            index += 5 ;
+
+            ByteUtil.hex2Bytes(para.commandCode, bsHead, index) ;
+
             index = 0 ;
             byte[] bs = new byte[13] ;
-            String ipPort = (String)para.param ;
-            String[] ipPorts = ipPort.split(",") ;
+            String[] ipPorts = cvo.ip.split(".") ;
             ByteUtilUnsigned.short2Bytes_LE(bs, (byte) Integer.parseInt(ipPorts[0]), index++);
             ByteUtilUnsigned.short2Bytes_LE(bs, (byte) Integer.parseInt(ipPorts[1]), index++);
             ByteUtilUnsigned.short2Bytes_LE(bs, (byte) Integer.parseInt(ipPorts[2]), index++);
             ByteUtilUnsigned.short2Bytes_LE(bs, (byte) Integer.parseInt(ipPorts[3]), index++);
-            ByteUtilUnsigned.short2Bytes_LE(bs, Integer.parseInt(ipPorts[4]), index);
+            ByteUtilUnsigned.short2Bytes_LE(bs, cvo.port, index);
             index += 2 ;
             GlCreate.createPw(bs, index);
             index += 2 ;
             GlCreate.createTp(bs, index);
 
             bytes = ByteUtil.bytesMerge(bsHead, bs) ;
+
+            GlCreate.createLen(bytes);//闀垮害鏀惧瓧鑺傛暟缁勪腑
+
+            byte[] bsTail = GlCreate.createCrcTail(bytes) ;//CRC鍜屽熬鍙犲姞瀛楄妭鏁扮粍涓�
+
+            bytes = ByteUtil.bytesMerge(bytes, bsTail) ;
+
+            return bytes ;
         }
 
-        GlCreate.createLen(bytes);//闀垮害鏀惧瓧鑺傛暟缁勪腑
-
-        byte[] bsTail = GlCreate.createCrcTail(bytes) ;//CRC鍜屽熬鍙犲姞瀛楄妭鏁扮粍涓�
-
-        bytes = ByteUtil.bytesMerge(bytes, bsTail) ;
-
-        return bytes ;
     }
 
 }

--
Gitblit v1.8.0