From a6ccb31191385dd9c3d2e9d75e1bcda7ff6a4ed3 Mon Sep 17 00:00:00 2001
From: bsw215583320 <baoshiwei121@163.com>
Date: 星期二, 12 九月 2023 14:47:57 +0800
Subject: [PATCH] 增加socket通讯,增加移动端控制接口

---
 jeecg-module-dry/jeecg-module-dry-biz/src/main/java/org/jeecg/modules/dry/service/impl/DryRealTimeDataServiceImpl.java |  100 +++++++++++++++++++++++++++++++++++++------------
 1 files changed, 75 insertions(+), 25 deletions(-)

diff --git a/jeecg-module-dry/jeecg-module-dry-biz/src/main/java/org/jeecg/modules/dry/service/impl/DryRealTimeDataServiceImpl.java b/jeecg-module-dry/jeecg-module-dry-biz/src/main/java/org/jeecg/modules/dry/service/impl/DryRealTimeDataServiceImpl.java
index 1c5b65d..a28e5cd 100644
--- a/jeecg-module-dry/jeecg-module-dry-biz/src/main/java/org/jeecg/modules/dry/service/impl/DryRealTimeDataServiceImpl.java
+++ b/jeecg-module-dry/jeecg-module-dry-biz/src/main/java/org/jeecg/modules/dry/service/impl/DryRealTimeDataServiceImpl.java
@@ -5,24 +5,32 @@
 import com.alibaba.fastjson.TypeReference;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import lombok.extern.slf4j.Slf4j;
+import org.apache.mina.core.service.IoAcceptor;
+import org.apache.mina.core.service.IoHandler;
+import org.apache.mina.core.session.IoSession;
 import org.jeecg.common.api.vo.Result;
 import org.jeecg.common.config.TenantContext;
 import org.jeecg.common.util.RedisUtil;
 import org.jeecg.modules.dry.common.CacheConstants;
 import org.jeecg.modules.dry.entity.*;
 import org.jeecg.modules.dry.service.*;
-import org.jeecg.modules.dry.vo.DryOrderTrendVo;
-import org.jeecg.modules.dry.vo.DryOrderVo;
-import org.jeecg.modules.dry.vo.RealTimeDataVo;
+import org.jeecg.modules.dry.socket.ServerHandler;
+import org.jeecg.modules.dry.socket.SocketServerConfig;
+import org.jeecg.modules.dry.vo.*;
 import org.jetbrains.annotations.NotNull;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
+import java.io.IOException;
+import java.io.ObjectOutputStream;
+import java.net.Socket;
 import java.text.DecimalFormat;
 import java.util.ArrayList;
 import java.util.List;
 import java.util.Map;
+import java.util.Set;
+
 @Slf4j
 @Service
 public class DryRealTimeDataServiceImpl implements IDryRealTimeDataService {
@@ -42,6 +50,9 @@
 
     @Autowired
     private IDryProdRecordService prodRecordService;
+
+    @Autowired
+    private IoAcceptor ioAcceptor;
 
     @Override
     @Transactional
@@ -88,6 +99,13 @@
         orderVo.setState_windbox(realTimeDataVo.getState_windbox());
         orderVo.setState_valve(realTimeDataVo.getState_valve());
         orderVo.setOrderStatus(realTimeDataVo.getWorkorder_status());
+
+        String fault = realTimeDataVo.getFault();
+//        String[] split = fault.split(",");
+//        for (String s : split) {
+//
+//        }
+
         DryOrderTrendVo trendVo = new DryOrderTrendVo(realTimeDataVo);
         // 2.2 淇濆瓨宸ュ崟鍚按鐜囧彉鍖� 鎴� 閲嶉噺鍙樺寲
 
@@ -283,32 +301,64 @@
 
         List<Double> dList = new ArrayList<>();
         DryOrderVo orderVo = (DryOrderVo) redisUtil.hget(CacheConstants.RedisKeyEnum.WORK_ORDER.getCode(), realTimeDataVo.getTenantid() + "_" + realTimeDataVo.getMachineid());
-try {
+            try {
 
 
-    if (dryEquipments != null && dryEquipments.size() > 0) {
-        dryEquipments.stream().forEach(item -> {
-            DryOrderVo order = (DryOrderVo) redisUtil.hget(CacheConstants.RedisKeyEnum.WORK_ORDER.getCode(), realTimeDataVo.getTenantid() + "_" + item.getCode());
-            if (order != null) {
-                double v = order.getOriginWeight() - order.getYield();
-                list.add(item.getName().substring(0, item.getName().indexOf('#')+1));
-                if (v > 0) {
-                    DecimalFormat df = new DecimalFormat("#.00");
-                    dList.add(Double.valueOf(df.format(v / order.getDryTime() * 60)));
-                } else {
-                    dList.add(50d);
+                if (dryEquipments != null && dryEquipments.size() > 0) {
+                    dryEquipments.stream().forEach(item -> {
+                        DryOrderVo order = (DryOrderVo) redisUtil.hget(CacheConstants.RedisKeyEnum.WORK_ORDER.getCode(), realTimeDataVo.getTenantid() + "_" + item.getCode());
+                        if (order != null) {
+                            double v = order.getOriginWeight() - order.getYield();
+                            list.add(item.getName().substring(0, item.getName().indexOf('#')+1));
+                            if (v > 0 && order.getDryTime()>0) {
+                                DecimalFormat df = new DecimalFormat("#.00");
+                                dList.add(Double.valueOf(df.format(v / order.getDryTime() * 60)));
+                            } else {
+                                dList.add(50d);
+                            }
+
+                        }
+                    });
                 }
+                if (orderVo != null) {
+                    orderVo.setCompEqpNum(list);
+                    orderVo.setCompEqpEffic(dList);
+                }
+            }catch (Exception e) {
+                e.printStackTrace();
+            }
+        return Result.ok(orderVo);
+    }
+
+
+    @Override
+    public Result<?> sendSocketMsg(CommandMessageVo msgVo) {
+
+
+        DryEquipment dryEquipment = equipmentService.selectByTenantIdEquipmentId(msgVo.getTenantId() + "", msgVo.getMachineId());
+        log.info("鑾峰彇璁惧锛�" + dryEquipment.toString());
+
+       // managedSessions.keySet().forEach(addr -> {
+           // ObjectOutputStream oos = null;
+            try {
+//                Socket socket = SocketServerConfig.clientMap.get(addr);
+                IoSession session = ServerHandler.clientSocket.get(dryEquipment.getIp());
+                if (session == null) {
+                    return Result.error("鏈幏鍙栧埌session,璇锋鏌ュ鎴风閰嶇疆鎴栬澶噄p閰嶇疆鏄惁姝e父");
+                }
+                SocketMsgVo smv = new SocketMsgVo(msgVo);
+                session.write(JSONObject.toJSONString(smv));
+//                oos = new ObjectOutputStream(socket.getOutputStream());
+//                String s = JSONObject.toJSONString(new SocketMsgVo(msgVo));
+//                oos.writeUTF(s);
+//                oos.flush();
+
+            } catch (Exception e) {
+                throw new RuntimeException(e);
+            } finally {
 
             }
-        });
-    }
-    if (orderVo != null) {
-        orderVo.setCompEqpNum(list);
-        orderVo.setCompEqpEffic(dList);
-    }
-}catch (Exception e) {
-    e.printStackTrace();
-}
-        return Result.ok(orderVo);
+     //   });
+        return Result.OK();
     }
 }

--
Gitblit v1.9.3