From 2ddf896f0edfa33e5421a7e34018e2d8f93684e6 Mon Sep 17 00:00:00 2001
From: fengxiang <fengxiang@blit.7drlb>
Date: Tue, 14 Nov 2017 13:10:29 +0800
Subject: [PATCH] 校准值

---
 src/main/java/com/moral/monitor/service/impl/RedisServiceImpl.java |   34 +++++------
 src/main/java/com/moral/monitor/listener/TaskListener.java         |  117 ++++++++++++++++++++------------------
 2 files changed, 76 insertions(+), 75 deletions(-)

diff --git a/src/main/java/com/moral/monitor/listener/TaskListener.java b/src/main/java/com/moral/monitor/listener/TaskListener.java
index a769e17..3dfe83a 100644
--- a/src/main/java/com/moral/monitor/listener/TaskListener.java
+++ b/src/main/java/com/moral/monitor/listener/TaskListener.java
@@ -56,71 +56,75 @@
     RedisService redisService;
     @Override
     public void onMessage(Message msg) {
+    	try {
+            String message = null;
+            try {
+                message = new String(msg.getBody(), "utf-8");
+            } catch (UnsupportedEncodingException e) {
+                logger.warn(e.getMessage());
+            }
 
-        String message = null;
-        try {
-            message = new String(msg.getBody(), "utf-8");
-        } catch (UnsupportedEncodingException e) {
-            logger.warn(e.getMessage());
-        }
+            Map<String, String> msgData = JSON.parseObject(message, new TypeReference<Map<String, String>>() {});
+            String mac = msgData.get("mac");
+            String ver = msgData.get("ver");
 
-        Map<String, String> msgData = JSON.parseObject(message, new TypeReference<Map<String, String>>() {});
-        String mac = msgData.get("mac");
-        String ver = msgData.get("ver");
-
-        if(StringUtils.isEmpty(ver) || StringUtils.isEmpty(mac)) {
-            return;
-        }
-        //���������������������������map
-        Map<String, Float> adjustMap = redisService.getAdjustsByMac(mac);
-        if(adjustMap!=null&&!adjustMap.isEmpty()) {
-            for (Map.Entry<String, Float> entry : adjustMap.entrySet()) {
-                String key = entry.getKey();
-                if(msgData.containsKey(key)) {
-                    Float value = entry.getValue();
-                    Float dataValue = Float.valueOf(msgData.get(key)) ;
-                    msgData.put(key, String.valueOf(dataValue + value));
+            if(StringUtils.isEmpty(ver) || StringUtils.isEmpty(mac)) {
+                return;
+            }
+            //���������������������������map 
+            Map<String, Float> adjustMap = redisService.getAdjustsByMac(mac);
+            if(adjustMap!=null&&!adjustMap.isEmpty()) {
+                for (Map.Entry<String, Float> entry : adjustMap.entrySet()) {
+                    String key = entry.getKey();
+                    if(msgData.containsKey(key)) {
+                        Float value = entry.getValue();
+                        Float dataValue = Float.valueOf(msgData.get(key)) ;
+                        msgData.put(key, String.valueOf(dataValue + value));
+                    }
                 }
             }
-        }
-//        System.out.println(message);
-//        System.out.println(JSON.toJSONString(msgData));
+//            System.out.println(message);
+//            System.out.println(JSON.toJSONString(msgData));
 
-        String new_message = JSON.toJSONString(msgData);
-        rabbitTemplate.convertAndSend("monitors_data2", "", new_message.getBytes());
-//        rabbitTemplate.send("monitors_data2", "", new Message(JSON.toJSONString(msgData).getBytes(), new MessageProperties()));
+            String new_message = JSON.toJSONString(msgData);
+            rabbitTemplate.convertAndSend("monitors_data2", "", new_message.getBytes());
+//            rabbitTemplate.send("monitors_data2", "", new Message(JSON.toJSONString(msgData).getBytes(), new MessageProperties()));
 
-//        int state = (new Random()).nextInt(4) % 5; //TODO
-          int state = detEquState(msgData);
-//        rabbitTemplate.convertAndSend("monitors_alarm", "", "{\"mac\": \"" + mac + "\", \"state\": " + state + "}");
+//            int state = (new Random()).nextInt(4) % 5; //TODO
+              int state = detEquState(msgData);
+//            rabbitTemplate.convertAndSend("monitors_alarm", "", "{\"mac\": \"" + mac + "\", \"state\": " + state + "}");
 
-        //������������������
-        jobDao.updateStateByMac(mac, state);
+            //������������������
+            jobDao.updateStateByMac(mac, state);
 
-//        //������������������
-//        taskDao.insertTologger(mac, message, getDate());
-        mongoTemplate.insert(message, "logger");
+//            //������������������
+//            taskDao.insertTologger(mac, message, getDate());
+            mongoTemplate.insert(message, "logger");
 
-        //������������������
-        List<History> histories = new ArrayList<History>();
-        List<Sensor> sensorList = taskDao.selectFromsensorByver(ver);
-        for (Sensor sensor : sensorList) {
-            String key = sensor.getMac_key();
-            if(msgData.containsKey(key)) {
-                //taskDao.insertTohistory(mac, sensor.getSensor(), key, msgData.get(key));
-                History history = new History();
-                history.setMac(mac);
-                history.setMac_key(key);
-                history.setTime(new Date(Long.parseLong(msgData.get("time"))));
-                history.setSensor(sensor.getSensor());
-                history.setMac_value(Double.valueOf(msgData.get(key)));
-                histories.add(history);
+            //������������������
+            List<History> histories = new ArrayList<History>();
+            List<Sensor> sensorList = taskDao.selectFromsensorByver(ver);
+            for (Sensor sensor : sensorList) {
+                String key = sensor.getMac_key();
+                if(msgData.containsKey(key)) {
+                    //taskDao.insertTohistory(mac, sensor.getSensor(), key, msgData.get(key));
+                    History history = new History();
+                    history.setMac(mac);
+                    history.setMac_key(key);
+                    history.setTime(new Date(Long.parseLong(msgData.get("time"))));
+                    history.setSensor(sensor.getSensor());
+                    history.setMac_value(Double.valueOf(msgData.get(key)));
+                    histories.add(history);
+                }
             }
-        }
-        jobDao.batchInsertHistory(histories);
+            jobDao.batchInsertHistory(histories);
 
-        //mongoTemplate.insert(JSON.toJSONString(histories), "data");
-        mongoTemplate.insert(new_message, "data");
+            //mongoTemplate.insert(JSON.toJSONString(histories), "data");
+            mongoTemplate.insert(new_message, "data");
+		} catch (Exception e) {
+			 //������������
+		     logger.error(e.getMessage());
+		}
     }
     //���������������������
     private static Map<String,Double[]> alarmLevles =new HashMap<String, Double[]>();
@@ -151,8 +155,9 @@
 	//���������������������������������������������
     private int detEquState(Map<String,String> data) {
     	int state = 0;
-    	data.remove("mac");//���������������mac������
     	Map<String, Object> equMap = new HashMap<String, Object>();
+    	String mac = data.get("mac");
+    	data.remove("mac");//���������������mac������
     	equMap.putAll(data);
     	if(data!=null) {
     			for(String key:alarmLevles.keySet()) {
@@ -182,7 +187,7 @@
     			}
     	}
     	equMap.put("state", state);//������������  
-    	redisService.setEquState(data.get("mac"),equMap);
+    	redisService.setEquState(mac,equMap);
     	return state;
     }
 }
diff --git a/src/main/java/com/moral/monitor/service/impl/RedisServiceImpl.java b/src/main/java/com/moral/monitor/service/impl/RedisServiceImpl.java
index b31ba9e..0859574 100644
--- a/src/main/java/com/moral/monitor/service/impl/RedisServiceImpl.java
+++ b/src/main/java/com/moral/monitor/service/impl/RedisServiceImpl.java
@@ -13,6 +13,7 @@
 import org.springframework.stereotype.Service;
 
 import com.alibaba.fastjson.JSON;
+import com.alibaba.fastjson.JSONObject;
 import com.alibaba.fastjson.TypeReference;
 import com.moral.monitor.dao.JobDao;
 import com.moral.monitor.service.RedisService;
@@ -38,6 +39,9 @@
     	return "static_equ_"+mac;
     }
     public void setStaticEqu(String mac,Map<String,Object> equMap) {
+    	 if(mac==null) {
+    		 throw new RuntimeException("Value for mac cannot be null");
+    	 }
 		 RedisUtil.set(redis, getStaticEquKey(mac),JSON.toJSONString(equMap));
     }
     public Map<String,Object> getStaticEqu(String mac) {
@@ -47,18 +51,18 @@
     	if(StringUtils.isEmpty(staticEquJson)) {
     		 equMap = jobDao.findEquWithAdjustsByMac(mac);
     		 if(equMap!=null) {
-     		    //���������������adjust������������
+     		    //list���map���������������adjust������������,
      	    	List<Map<String,Object>> adjustList = (List<Map<String, Object>>) equMap.get(ADJUSTS);
-     	    	List<Object> adjustListWithData = new ArrayList<Object>();
+     	    	Map<String,String> adjustMap = new HashMap();
      	    	//list to map
      	    	for(Map<String,Object> adjust:adjustList) {
-     	    		if(adjust.get("value")!=null) {
+     	    		if(adjust.get("value")!=null&&Float.parseFloat(adjust.get("value").toString())!=0.0) {
      	    			//������������������
-     	    			adjustListWithData.add(adjust);
+     	    			adjustMap.put(adjust.get("key").toString(), adjust.get("value").toString());
      	    		}
      	    	}
-        	     equMap.put(ADJUSTS,adjustListWithData);
-         		 setStaticEqu(mac,equMap);
+        	    equMap.put(ADJUSTS,adjustMap);
+         		setStaticEqu(mac,equMap);
     		 }
     	}else {
     		 equMap = JSON.parseObject(staticEquJson,new TypeReference<Map<String,Object>>(){});
@@ -70,20 +74,12 @@
      */
     public Map<String,Float> getAdjustsByMac(String mac){
     	Map<String,Object> equMap = getStaticEqu(mac);
+    	Object adjusts = equMap.get(ADJUSTS);
     	Map<String,Float> adjustMap = null;
-    	if(equMap!=null) {
-        	 List<Map<String,Object>> adjustList = (List<Map<String, Object>>) equMap.get(ADJUSTS);
-        	 if(adjustList!=null) {
-        		 adjustMap = new HashMap<String, Float>();
-             	//list to map
-             	for(Map<String,Object> adjust:adjustList) {
-             		if(adjust.get("value")!=null) {
-             			adjustMap.put(adjust.get("key").toString(), Float.valueOf(adjust.get("value").toString()));
-             		}
-             	}
-        	 }
-    	}
-    	return adjustMap;
+        if(adjusts!=null&&adjusts instanceof JSONObject) {
+        	adjustMap = ((JSONObject)adjusts).toJavaObject(new TypeReference<Map<String,Float>>(){});
+        }
+        return adjustMap;
     }
     //���������state_������ID_������ID_���������ID_mac
     private String getEquStateKey(String mac) {

--
Gitblit v1.8.0