From 85b2001c0ec2f1adc598db3bf47ad457dcca7074 Mon Sep 17 00:00:00 2001
From: dengzedong <dengzedong@email>
Date: 星期四, 19 十二月 2024 16:37:53 +0800
Subject: [PATCH] item-chart 空point校验

---
 iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/point/collection/handler/MeasureHandle.java |   16 +++++++++++-----
 1 files changed, 11 insertions(+), 5 deletions(-)

diff --git a/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/point/collection/handler/MeasureHandle.java b/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/point/collection/handler/MeasureHandle.java
index bec67f1..c97aa8b 100644
--- a/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/point/collection/handler/MeasureHandle.java
+++ b/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/point/collection/handler/MeasureHandle.java
@@ -83,7 +83,9 @@
                 kioTagIds.add(new String[]{item.getSourceId(), item.getTagNo()});
             } else if (DataSourceType.HTTP.getCode().equals(item.getSourceType())) {
                 if (SourceApiEnum.iHyperDB.getCode().equals(item.getSourceName())) {
-                    httpTagIhd.add(new Object[]{item.getSourceId(), item.getTagNo(), item.getDimension(), item.getValueType()});
+                    if (item.getTagNo() != null && item.getDimension() != null && item.getValueType() != null) {
+                        httpTagIhd.add(new Object[]{item.getSourceId(), item.getTagNo(), item.getDimension(), item.getValueType()});
+                    }
                 }
             }
         });
@@ -102,7 +104,7 @@
             tagValues.putAll(kingIOCollector.getTagValues(kioTagIds));
         }
         if (!CollectionUtils.isEmpty(httpTagIhd)) {
-            tagValues.putAll(httpCollectorForIhd.getTagValues(httpTagIhd));
+            tagValues.putAll(httpCollectorForIhd.getTagValues(httpTagIhd, collectTime));
         }
         this.toCommonResult(collectTime, dtos, tagValues, dataMap, result);
         log.info("测量点处理结束");
@@ -133,12 +135,17 @@
     private Object handleData(DaPointDTO dto, Object value) {
         Object result = value;
         try {
+            if (value == null) {
+                return CommonConstant.BAD_VALUE;
+            }
             if (DataTypeEnum.FLOAT.getCode().equals(dto.getDataType()) || DataTypeEnum.INT.getCode().equals(dto.getDataType())) {
                 BigDecimal rawValue = new BigDecimal(value.toString());
-
+                if(CommonConstant.BAD_VALUE.compareTo(rawValue) == 0) {
+                    return CommonConstant.BAD_VALUE;
+                }
                 // 异常值处理
                 if (rawValue.compareTo(maxValue) > 0 || rawValue.compareTo(minValue) < 0) {
-                    rawValue = CommonConstant.BAD_VALUE;
+                    return CommonConstant.BAD_VALUE;
                 }
                 BigDecimal coefficient = dto.getUnittransfactor() == null ? BigDecimal.ONE : dto.getUnittransfactor();
                 BigDecimal calValue = rawValue.multiply(coefficient);
@@ -157,7 +164,6 @@
             } else if (DataTypeEnum.BOOLEAN.getCode().equals(dto.getDataType())) {
                 result = Boolean.parseBoolean(value.toString());
             }
-
         } catch (Exception ex) {
             log.warn("handleData异常,PointNo=" + dto.getPointNo());
             ex.printStackTrace();

--
Gitblit v1.9.3