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