From 750d08105ea928e547ec721c367a70ac946a0aef Mon Sep 17 00:00:00 2001
From: zhubaomin <zhubaomin>
Date: 星期五, 29 十一月 2024 14:54:49 +0800
Subject: [PATCH] App文件上传功能

---
 pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V202404/parse/global/GlCreate.java |   69 +++++++++++++++-------------------
 1 files changed, 30 insertions(+), 39 deletions(-)

diff --git a/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V202404/parse/global/GlCreate.java b/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V202404/parse/global/GlCreate.java
index 9a0db38..432a0bf 100644
--- a/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V202404/parse/global/GlCreate.java
+++ b/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V202404/parse/global/GlCreate.java
@@ -1,12 +1,10 @@
 package com.dy.common.mw.protocol.p206V202404.parse.global;
 
-import com.dy.common.mw.protocol.p206V1_0_0.ProtocolConstantV206V1_0_0;
+import com.dy.common.mw.protocol.p206V1.ProtocolConstantV206V1;
+import com.dy.common.mw.protocol.p206V2.ProtocolConstantV206V2;
 import com.dy.common.mw.protocol.p206V202404.CommonV202404;
 import com.dy.common.mw.protocol.p206V202404.ProtocolConstantV206V202404;
-import com.dy.common.util.ByteUtil;
-import com.dy.common.util.ByteUtilUnsigned;
-import com.dy.common.util.CRC8_for_2_0;
-import com.dy.common.util.DateTime;
+import com.dy.common.util.*;
 
 public class GlCreate {
     /**
@@ -55,6 +53,16 @@
 
         Integer rtuAddr2Int = Integer.parseInt(rtuAddr2) ;
         ByteUtilUnsigned.short2Bytes_LE(bs, rtuAddr2Int.shortValue(), index);
+    }
+    /**
+     * 涓哄崌绾у崗璁�
+     * @param rtuAddr
+     * @param bs
+     * @param index
+     * @throws Exception
+     */
+    public static void createRtuAddr4PUg(String rtuAddr, byte[] bs, int index) throws Exception {
+        ByteUtil.string2BCD_BE(bs, rtuAddr, index) ;
     }
 
     /**
@@ -114,35 +122,16 @@
         ByteUtil.string2BCD_BE(bs, DateTime.mm(), index + 1) ;
         ByteUtil.string2BCD_BE(bs, DateTime.HH(), index + 2) ;
         ByteUtil.string2BCD_BE(bs, DateTime.dd(), index + 3) ;
+
+        byte week = DateTime.week_Int().byteValue() ;
         byte month = Byte.parseByte(DateTime.MM()) ;
-        byte week = (byte)(DateTime.week_Int().byteValue() << 1)  ;
-        String month1 = "0" ;
-        String month2 = "0" ;
         if(month < 10){
-            month1 = "" + month ;
+            bs[index + 4] = (byte)((week << 5) | month) ;
         }else{
-            if(month == 10){
-                month1 = "0" ;
-            }else if(month == 11){
-                month1 = "1" ;
-            }else if(month == 12){
-                month1 = "2" ;
-            }
-            week = (byte)(week | 0x01) ;
+            bs[index + 4] = (byte)((week << 5) | 0x10 | (month - 10)) ;
         }
-        month2 = "" + week ;
 
-        ByteUtil.string2BCD_BE(bs, month2 + month1, index + 4) ;
         ByteUtil.string2BCD_BE(bs, DateTime.yy(), index + 5) ;
-
-        /*
-        bs[index] = Byte.parseByte(DateTime.ss()) ;
-        bs[index + 1] = Byte.parseByte(DateTime.mm()) ;
-        bs[index + 2] = Byte.parseByte(DateTime.HH()) ;
-        bs[index + 3] = Byte.parseByte(DateTime.dd()) ;
-        bs[index + 4] = (byte)(DateTime.week_Int().byteValue() << 5 | Byte.parseByte(DateTime.MM())) ;
-        bs[index + 5] = Byte.parseByte(DateTime.yy()) ;
-        */
     }
 
     public static void createS2D(byte[] bs, int index) throws Exception {
@@ -150,24 +139,26 @@
         ByteUtil.string2BCD_BE(bs, DateTime.mm(), index + 1) ;
         ByteUtil.string2BCD_BE(bs, DateTime.HH(), index + 2) ;
         ByteUtil.string2BCD_BE(bs, DateTime.dd(), index + 3) ;
-        /*
-        bs[index] = Byte.parseByte(DateTime.ss()) ;
-        bs[index + 1] = Byte.parseByte(DateTime.mm()) ;
-        bs[index + 2] = Byte.parseByte(DateTime.HH()) ;
-        bs[index + 3] = Byte.parseByte(DateTime.dd()) ;
-        */
     }
 
     public static void createLen(byte[] bsNoTail) throws Exception {
-        int len = bsNoTail.length - ProtocolConstantV206V1_0_0.lenHead2ctrl;
-        bsNoTail[ProtocolConstantV206V1_0_0.dataLenIndex] = (byte)len ;
+        int len = bsNoTail.length - ProtocolConstantV206V1.lenHead2ctrl;
+        bsNoTail[ProtocolConstantV206V1.dataLenIndex] = (byte)len ;
     }
 
     public static byte[] createCrcTail(byte[] bsNoTail) throws Exception {
-        int crc = new CRC8_for_2_0().CRC8(bsNoTail, ProtocolConstantV206V1_0_0.ctrlIndex, bsNoTail.length -1) ;
-        byte[] bytes = new byte[ProtocolConstantV206V1_0_0.lenTail] ;
+        int crc = new CRC8_for_2_0().CRC8(bsNoTail, ProtocolConstantV206V1.ctrlIndex, bsNoTail.length -1) ;
+        byte[] bytes = new byte[ProtocolConstantV206V1.lenTail] ;
         bytes[0] = (byte)crc ;
-        bytes[1] = ProtocolConstantV206V1_0_0.P_Tail_Byte ;
+        bytes[1] = ProtocolConstantV206V1.P_Tail_Byte ;
+        return bytes ;
+    }
+
+    public static byte[] createCrcTail4Ug(byte[] bsNoTail) throws Exception {
+        int crc = new CRC16().CRC(bsNoTail, 0, bsNoTail.length -1) ;
+        byte[] bytes = new byte[ProtocolConstantV206V2.UG_lenTail] ;
+        ByteUtilUnsigned.short2Bytes_BE(bytes, crc, 0);
+        bytes[2] = ProtocolConstantV206V2.P_Tail_Byte ;
         return bytes ;
     }
 

--
Gitblit v1.8.0