From 433bb0003d9341647576251c9031148fb8145d43 Mon Sep 17 00:00:00 2001
From: liurunyu <lry9898@163.com>
Date: 星期三, 26 六月 2024 16:10:57 +0800
Subject: [PATCH] 1、通信协议报警解析部分修改; 2、SsoCtrl.java中增加注释; 3、代码完善。

---
 pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V202404/parse/global/GlParse.java |  263 +++++++++++++++++++++++++---------------------------
 1 files changed, 128 insertions(+), 135 deletions(-)

diff --git a/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V202404/parse/global/GlParse.java b/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V202404/parse/global/GlParse.java
index 2fafab2..e81594f 100644
--- a/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V202404/parse/global/GlParse.java
+++ b/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V202404/parse/global/GlParse.java
@@ -1,9 +1,7 @@
 package com.dy.common.mw.protocol.p206V202404.parse.global;
 
 import com.dy.common.mw.protocol.p206V202404.ProtocolConstantV206V202404;
-import com.dy.common.mw.protocol.p206V202404.upVos.DataCd80_5BVo;
-import com.dy.common.mw.protocol.p206V202404.upVos.DataCd81Vo;
-import com.dy.common.mw.protocol.p206V202404.upVos.DataCd93_A3Vo;
+import com.dy.common.mw.protocol.p206V202404.upVos.*;
 import com.dy.common.util.ByteUtil;
 import com.dy.common.util.ByteUtilUnsigned;
 import org.apache.logging.log4j.LogManager;
@@ -32,7 +30,7 @@
         String mm = ByteUtil.BCD2String_BE(bs, index, index) ;
         index++ ;
         String yy = ByteUtil.BCD2String_BE(bs, index, index) ;
-        return yy + "-" + mm + "-" + dd + " " + HH + ":" + MM + ":" + ss ;
+        return "20" + yy + "-" + mm + "-" + dd + " " + HH + ":" + MM + ":" + ss ;
     }
    /**
      * 鍒嗘瀽IC鍗$紪鍙�
@@ -45,93 +43,39 @@
      */
     public static String parseIcCardNo(byte[] bs, int index, int len1, int len2)throws Exception{
         String rtuAddrBCD = "" + ByteUtil.BCD2Long_BE(bs, index, index + len1 - 1) ;
-        String rtuAddrStr = "" + ByteUtilUnsigned.bytes2Short_LE(bs, index + len1 + len2 -1 ) ;
+        String rtuAddrStr = "" + ByteUtilUnsigned.bytes2Short_LE(bs, index + len1) ;
         while(rtuAddrStr.length() < 5){
             rtuAddrStr = "0" + rtuAddrStr ;
         }
         return rtuAddrBCD + rtuAddrStr ;
     }
 
+
     /**
      * 鍒嗘瀽鐘舵�佷笌鎶ヨ
-     * @param bs
-     * @param index
+     * @param bs 涓婃姤鏁版嵁鐨勫瓧鑺傛暟缁�
+     * @param index 褰撳墠瑙f瀽鏁扮粍涓嬫爣浣嶇疆
      * @return
      */
-    public static void parseAlarmAndState(byte[] bs, int index, DataCd80_5BVo vo){
+    public static void parseAlarmAndState(byte[] bs, int index, AlarmVo vo){
         byte b = bs[index] ;
         vo.statePump = (byte)(b & 0x1) ;
-        vo.alarmWaterRemain = (byte)(b & 0x2) ;
-        vo.alarm0WaterRemain = (byte)(b & 0x4) ;
-        vo.alarmExceedYear = (byte)(b & 0x8) ;
-        vo.alarmWaterMeterFault = (byte)(b & 0x10) ;
-        vo.alarmSteal = (byte)(b & 0x20) ;
-        vo.alarmWaterMeterBreak = (byte)(b & 0x40) ;
-        vo.alarmEleMeterFault = (byte)(b & 0x80) ;
+        vo.alarmWaterRemain = (byte)((b >> 1) & 1) ;
+        vo.alarm0WaterRemain = (byte)((b >> 2) & 1) ;
+        vo.alarmExceedYear = (byte)((b >> 3) & 1) ;
+        vo.alarmWaterMeterFault = (byte)((b >> 4) & 1) ;
+        vo.alarmSteal = (byte)((b >> 5) & 1) ;
+        vo.alarmWaterMeterBreak = (byte)((b >> 6) & 1) ;
+        vo.alarmEleMeterFault = (byte)((b >> 7) & 1) ;
 
-        index++ ;
-        b = bs[index] ;
+        b = bs[index + 1] ;
         vo.alarm0MoneyRemain = (byte)(b & 0x1) ;
-        vo.alarmInnerDoor = (byte)(b & 0x2) ;
-        vo.alarmOuterDoor = (byte)(b & 0x4) ;
-        vo.alarmEleMiss = (byte)(b & 0x8) ;
-        vo.alarmEleExceed = (byte)(b & 0x10) ;
-        vo.alarmEleLowVolt = (byte)(b & 0x20) ;
-        vo.stateIcEnable = (byte)(b & 0x40) ;
-    }
-    /**
-     * 鍒嗘瀽鐘舵�佷笌鎶ヨ
-     * @param bs
-     * @param index
-     * @return
-     */
-    public static void parseAlarmAndState(byte[] bs, int index, DataCd81Vo vo){
-        byte b = bs[index] ;
-        vo.statePump = (byte)(b & 0x1) ;
-        vo.alarmWaterRemain = (byte)(b & 0x2) ;
-        vo.alarm0WaterRemain = (byte)(b & 0x4) ;
-        vo.alarmExceedYear = (byte)(b & 0x8) ;
-        vo.alarmWaterMeterFault = (byte)(b & 0x10) ;
-        vo.alarmSteal = (byte)(b & 0x20) ;
-        vo.alarmWaterMeterBreak = (byte)(b & 0x40) ;
-        vo.alarmEleMeterFault = (byte)(b & 0x80) ;
-
-        index++ ;
-        b = bs[index] ;
-        vo.alarm0MoneyRemain = (byte)(b & 0x1) ;
-        vo.alarmInnerDoor = (byte)(b & 0x2) ;
-        vo.alarmOuterDoor = (byte)(b & 0x4) ;
-        vo.alarmEleMiss = (byte)(b & 0x8) ;
-        vo.alarmEleExceed = (byte)(b & 0x10) ;
-        vo.alarmEleLowVolt = (byte)(b & 0x20) ;
-        vo.stateIcEnable = (byte)(b & 0x40) ;
-    }
-    /**
-     * 鍒嗘瀽鐘舵�佷笌鎶ヨ
-     * @param bs
-     * @param index
-     * @return
-     */
-    public static void parseAlarmAndState(byte[] bs, int index, DataCd93_A3Vo vo){
-        byte b = bs[index] ;
-        vo.statePump = (byte)(b & 0x1) ;
-        vo.alarmWaterRemain = (byte)(b & 0x2) ;
-        vo.alarm0WaterRemain = (byte)(b & 0x4) ;
-        vo.alarmExceedYear = (byte)(b & 0x8) ;
-        vo.alarmWaterMeterFault = (byte)(b & 0x10) ;
-        vo.alarmSteal = (byte)(b & 0x20) ;
-        vo.alarmWaterMeterBreak = (byte)(b & 0x40) ;
-        vo.alarmEleMeterFault = (byte)(b & 0x80) ;
-
-        index++ ;
-        b = bs[index] ;
-        vo.alarm0MoneyRemain = (byte)(b & 0x1) ;
-        vo.alarmInnerDoor = (byte)(b & 0x2) ;
-        vo.alarmOuterDoor = (byte)(b & 0x4) ;
-        vo.alarmEleMiss = (byte)(b & 0x8) ;
-        vo.alarmEleExceed = (byte)(b & 0x10) ;
-        vo.alarmEleLowVolt = (byte)(b & 0x20) ;
-        vo.stateIcEnable = (byte)(b & 0x40) ;
+        vo.alarmInnerDoor = (byte)((b >> 1) & 1) ;
+        vo.alarmOuterDoor = (byte)((b >> 2) & 1) ;
+        vo.alarmEleMiss = (byte)((b >> 3) & 1) ;
+        vo.alarmEleExceed = (byte)((b >> 4) & 1) ;
+        vo.alarmEleLowVolt = (byte)((b >> 5) & 1) ;
+        vo.stateIcEnable = (byte)((b >> 6) & 1) ;
     }
 
     public static String parseTp(byte[] bs, short index){
@@ -145,7 +89,7 @@
             index++ ;
             dt = ByteUtil.BCD2String_BE(bs, index, index) + " " + dt ;//鏃�
             index++ ;
-            //bs[index] = (byte)(bs[index] & 0x10);
+            bs[index] = (byte)(bs[index] & 0x1F);
             dt = ByteUtil.BCD2String_BE(bs, index, index) + "-" + dt ;//鏈�
             index++ ;
             dt = "20" + ByteUtil.BCD2String_BE(bs, index, index) + "-" + dt ;//骞�
@@ -172,7 +116,7 @@
         cdData.useWaterType = bs[index];
 
         index++ ;
-        cdData.orderNo = ByteUtil.BCD2String_BE(bs, index, index + 4) ;
+        cdData.orderNo = ByteUtil.BCD2String_BE(bs, index, index + 7) ;
 
         index += 8 ;
         cdData.icCardAddr = ByteUtil.bytes2Hex(bs, false, index, 4) ;
@@ -184,108 +128,166 @@
         cdData.rtuDt  = GlParse.parseRtuDt(bs, index) ;
 
         index += 6 ;
-        int waterLevel = ByteUtil.BCD2Int_BE(bs, index, index + 3) ;
+        Long waterLevel = ByteUtil.BCD2Long_LE(bs, index, index + 3) ;
         cdData.waterLevel = waterLevel/1000.0D;
 
         index += 4 ;
-        int waterPress = ByteUtil.BCD2Int_BE(bs, index, index + 2) ;
+        int waterPress = ByteUtil.BCD2Int_LE(bs, index, index + 2) ;
         cdData.waterPress = waterPress/100.0D;
 
         index += 3 ;
-        int waterInstant = ByteUtil.BCD2Int_BE(bs, index, index + 3) ;
+        Long waterInstant = ByteUtil.BCD2Long_LE(bs, index, index + 3) ;
         cdData.waterInstant = waterInstant/100.0D;
 
         index += 4 ;
-        int waterTotal = ByteUtil.BCD2Int_BE(bs, index, index + 4) ;
+        Long waterTotal = ByteUtil.BCD2Long_LE(bs, index, index + 4) ;
         cdData.waterTotal = waterTotal/100.0D;
 
         index += 5 ;
-        int eleTotal = ByteUtil.BCD2Int_BE(bs, index, index + 4) ;
+        Long eleTotal = ByteUtil.BCD2Long_LE(bs, index, index + 4) ;
         cdData.eleTotal = eleTotal/100.0D;
 
         index += 5 ;
-        int moneyRemain = ByteUtil.BCD2Int_BE(bs, index, index + 4) ;
+        Long moneyRemain = ByteUtil.BCD2Long_LE(bs, index, index + 4) ;
         cdData.moneyRemain = moneyRemain/100.0D;
 
         index += 5 ;
-        int waterRemain = ByteUtil.BCD2Int_BE(bs, index, index + 4) ;
+        Long waterRemain = ByteUtil.BCD2Long_LE(bs, index, index + 4) ;
         cdData.waterRemain = waterRemain/100.0D;
 
         index += 5 ;
-        int thisEle = ByteUtil.BCD2Int_BE(bs, index, index + 3) ;
+        int thisEle = ByteUtil.BCD2Int_LE(bs, index, index + 3) ;
         cdData.thisEle = thisEle/100.0D;
 
         index += 4 ;
-        int thisWater = ByteUtil.BCD2Int_BE(bs, index, index + 3) ;
+        int thisWater = ByteUtil.BCD2Int_LE(bs, index, index + 3) ;
         cdData.thisWater = thisWater/100.0D;
 
         index += 4 ;
-        int thisMoney = ByteUtil.BCD2Int_BE(bs, index, index + 3) ;
+        int thisMoney = ByteUtil.BCD2Int_LE(bs, index, index + 3) ;
         cdData.thisMoney = thisMoney/100.0D;
 
         index += 4 ;
-        cdData.thisDuration = ByteUtil.BCD2Int_BE(bs, index, index + 1) ;
+        cdData.thisDuration = ByteUtil.BCD2Int_LE(bs, index, index + 1) ;
 
         index += 2 ;
-        int waterPrice = ByteUtil.BCD2Int_BE(bs, index, index + 1) ;
+        int waterPrice = ByteUtil.BCD2Int_LE(bs, index, index + 1) ;
         cdData.waterPrice = waterPrice/100.0D;
 
         index += 2 ;
-        int elePrice = ByteUtil.BCD2Int_BE(bs, index, index + 1) ;
+        int elePrice = ByteUtil.BCD2Int_LE(bs, index, index + 1) ;
         cdData.elePrice = elePrice/100.0D;
 
         index += 2 ;
-        GlParse.parseAlarmAndState(bs, index, cdData) ;
+        GlParse.parseAlarmAndState(bs, index, cdData) ;//鍥涗釜瀛楄妭
 
-        index += 2 ;
-        int aVolt = ByteUtil.BCD2Int_BE(bs, index, index + 1) ;
+        index += 4 ;
+        int aVolt = ByteUtil.BCD2Int_LE(bs, index, index + 1) ;
         cdData.aVolt = aVolt/10.0D;
 
         index += 2 ;
-        int bVolt = ByteUtil.BCD2Int_BE(bs, index, index + 1) ;
+        int bVolt = ByteUtil.BCD2Int_LE(bs, index, index + 1) ;
         cdData.bVolt = bVolt/10.0D;
 
         index += 2 ;
-        int cVolt = ByteUtil.BCD2Int_BE(bs, index, index + 1) ;
+        int cVolt = ByteUtil.BCD2Int_LE(bs, index, index + 1) ;
         cdData.cVolt = cVolt/10.0D;
 
         index += 2 ;
-        int aCurrent = ByteUtil.BCD2Int_BE(bs, index, index + 1) ;
+        int aCurrent = ByteUtil.BCD2Int_LE(bs, index, index + 1) ;
         cdData.aCurrent = aCurrent/10.0D;
 
         index += 2 ;
-        int bCurrent = ByteUtil.BCD2Int_BE(bs, index, index + 1) ;
+        int bCurrent = ByteUtil.BCD2Int_LE(bs, index, index + 1) ;
         cdData.bCurrent = bCurrent/10.0D;
 
         index += 2 ;
-        int cCurrent = ByteUtil.BCD2Int_BE(bs, index, index + 1) ;
+        int cCurrent = ByteUtil.BCD2Int_LE(bs, index, index + 1) ;
         cdData.cCurrent = cCurrent/10.0D;
 
         index += 2 ;
-        int batteryVolt = ByteUtil.BCD2Int_BE(bs, index, index + 1) ;
+        int batteryVolt = ByteUtil.BCD2Int_LE(bs, index, index + 1) ;
         cdData.batteryVolt = batteryVolt/100.0D;
 
         index += 2 ;
-        int waterMeterTransVolt = ByteUtil.BCD2Int_BE(bs, index, index + 1) ;
+        int waterMeterTransVolt = ByteUtil.BCD2Int_LE(bs, index, index + 1) ;
         cdData.waterMeterTransVolt = waterMeterTransVolt/100.0D;
 
         index += 2 ;
-        int waterMeterWorkVolt = ByteUtil.BCD2Int_BE(bs, index, index + 1) ;
+        int waterMeterWorkVolt = ByteUtil.BCD2Int_LE(bs, index, index + 1) ;
         cdData.waterMeterWorkVolt = waterMeterWorkVolt/100.0D;
 
         index += 2 ;
-        cdData.csq = ByteUtil.BCD2Int_BE(bs, index, index) ;
+        cdData.csq = ByteUtil.BCD2Int_LE(bs, index, index) ;
 
     }
 
 
     /**
-     * 鍒嗘瀽鍔熻兘93銆丄3鍜�85鏁版嵁
+     * 鍒嗘瀽鍔熻兘85鏁版嵁
      * @param bs
      * @param cdData
      * @throws Exception
      */
-    public static void parseCd93A3And85(byte[] bs, DataCd93_A3Vo cdData) throws Exception {
+    public static void parseCd85(byte[] bs, DataCd85Vo cdData) throws Exception {
+        int index = ProtocolConstantV206V202404.dataIndex ;
+        cdData.controllerType = ByteUtil.bytes2Hex(bs, false, index, 1) ;
+
+        index++ ;
+        cdData.projectNo = (int)bs[index];
+
+        index ++ ;
+        cdData.opType = bs[index];
+
+        index++ ;
+        cdData.icCardAddr = ByteUtil.bytes2Hex(bs, false, index, 4) ;
+
+        index += 4 ;
+        cdData.icCardNo = GlParse.parseIcCardNo(bs, index, 6, 2) ;
+
+        index += 8 ;
+        cdData.orderNo = ByteUtil.BCD2String_BE(bs, index, index + 7) ;
+
+        index += 8 ;
+        cdData.startDt  = GlParse.parseRtuDt(bs, index) ;
+
+        index += 6 ;
+        cdData.endDt  = GlParse.parseRtuDt(bs, index) ;
+
+        index += 6 ;
+        cdData.waterTotalAmount = ByteUtil.BCD2Long_LE(bs, index, index + 4)/100.0D ;
+
+        index += 5 ;
+        cdData.eleTotalAmount = ByteUtil.BCD2Long_LE(bs, index, index + 4)/100.0D ;
+
+        index += 5 ;
+        cdData.moneyRemain = ByteUtil.BCD2Long_LE(bs, index, index + 4)/100.0D ;
+
+        index += 5 ;
+        cdData.waterRemain = ByteUtil.BCD2Long_LE(bs, index, index + 4)/100.0D ;
+
+        index += 5 ;
+        cdData.thisEle = ByteUtil.BCD2Long_LE(bs, index, index + 3)/100.0D ;
+
+        index += 4 ;
+        cdData.thisWater = ByteUtil.BCD2Long_LE(bs, index, index + 3)/100.0D ;
+
+        index += 4 ;
+        cdData.thisMoney = ByteUtil.BCD2Long_LE(bs, index, index + 3)/100.0D ;
+
+        index += 4 ;
+        cdData.thisDuration = ByteUtil.BCD2Int_LE(bs, index, index + 1) ;
+
+        index += 2 ;
+        GlParse.parseAlarmAndState(bs, index, cdData) ;//鍥涗釜瀛楄妭
+    }
+    /**
+     * 鍒嗘瀽鍔熻兘93銆丄3鏁版嵁
+     * @param bs
+     * @param cdData
+     * @throws Exception
+     */
+    public static void parseCd93A3(byte[] bs, DataCd93_A3Vo cdData) throws Exception {
         int index = ProtocolConstantV206V202404.dataIndex ;
         cdData.controllerType = ByteUtil.bytes2Hex(bs, false, index, 1) ;
 
@@ -301,57 +303,48 @@
         index++ ;
         cdData.icCardAddr = ByteUtil.bytes2Hex(bs, false, index, 4) ;
 
-        index += 8 ;
+        index += 4 ;
         cdData.icCardNo = GlParse.parseIcCardNo(bs, index, 6, 2) ;
 
         index += 8 ;
         cdData.orderNo = ByteUtil.BCD2String_BE(bs, index, index + 7) ;
 
-        index ++ ;
-        String mm = ByteUtil.BCD2String_LE(bs, index, index) ;
-        index ++ ;
-        String HH = ByteUtil.BCD2String_LE(bs, index, index) ;
-        index ++ ;
-        String dd = ByteUtil.BCD2String_LE(bs, index, index) ;
-        index ++ ;
-        String MM = ByteUtil.BCD2String_LE(bs, index, index) ;
-        cdData.startDt = MM + "鏈�" + dd + "鏃�" + HH + "鏃�" + mm + "鍒�" ;
+        index += 8 ;
+        cdData.startDt  = GlParse.parseRtuDt(bs, index) ;
 
-        index ++ ;
-        mm = ByteUtil.BCD2String_LE(bs, index, index) ;
-        index ++ ;
-        HH = ByteUtil.BCD2String_LE(bs, index, index) ;
-        index ++ ;
-        dd = ByteUtil.BCD2String_LE(bs, index, index) ;
-        index ++ ;
-        MM = ByteUtil.BCD2String_LE(bs, index, index) ;
-        cdData.endDt = MM + "鏈�" + dd + "鏃�" + HH + "鏃�" + mm + "鍒�" ;
+        if(cdData.opResult == (byte)0x81){
+            //澶辫触浜嗭紝涓嬮潰灏辨病鏈夋暟鎹簡
+            return ;
+        }
 
-        index ++ ;
-        cdData.waterTotalAmount = ByteUtil.BCD2Int_BE(bs, index, index + 4)/100.0D ;
+        index += 6 ;
+        cdData.endDt  = GlParse.parseRtuDt(bs, index) ;
+
+        index += 6 ;
+        cdData.waterTotalAmount = ByteUtil.BCD2Long_LE(bs, index, index + 4)/100.0D ;
 
         index += 5 ;
-        cdData.eleTotalAmount = ByteUtil.BCD2Int_BE(bs, index, index + 4)/100.0D ;
+        cdData.eleTotalAmount = ByteUtil.BCD2Long_LE(bs, index, index + 4)/100.0D ;
 
         index += 5 ;
-        cdData.moneyRemain = ByteUtil.BCD2Int_BE(bs, index, index + 4)/100.0D ;
+        cdData.moneyRemain = ByteUtil.BCD2Long_LE(bs, index, index + 4)/100.0D ;
 
         index += 5 ;
-        cdData.waterRemain = ByteUtil.BCD2Int_BE(bs, index, index + 4)/100.0D ;
+        cdData.waterRemain = ByteUtil.BCD2Long_LE(bs, index, index + 4)/100.0D ;
 
         index += 5 ;
-        cdData.thisEle = ByteUtil.BCD2Int_BE(bs, index, index + 3)/100.0D ;
+        cdData.thisEle = ByteUtil.BCD2Long_LE(bs, index, index + 3)/100.0D ;
 
         index += 4 ;
-        cdData.thisWater = ByteUtil.BCD2Int_BE(bs, index, index + 3)/100.0D ;
+        cdData.thisWater = ByteUtil.BCD2Long_LE(bs, index, index + 3)/100.0D ;
 
         index += 4 ;
-        cdData.thisMoney = ByteUtil.BCD2Int_BE(bs, index, index + 3)/100.0D ;
+        cdData.thisMoney = ByteUtil.BCD2Long_LE(bs, index, index + 3)/100.0D ;
 
         index += 4 ;
-        cdData.thisDuration = ByteUtil.BCD2Int_BE(bs, index, index + 1) ;
+        cdData.thisDuration = ByteUtil.BCD2Int_LE(bs, index, index + 1) ;
 
         index += 2 ;
-        GlParse.parseAlarmAndState(bs, index, cdData) ;
+        GlParse.parseAlarmAndState(bs, index, cdData) ;//鍥涗釜瀛楄妭
     }
 }

--
Gitblit v1.8.0