package com.dy.testClient.tcpClient; import com.dy.common.mw.protocol.p206V1_0_0.CommonV1_0_1; import com.dy.common.mw.protocol.p206V1_0_0.ProtocolConstantV206V1_0_0; import com.dy.common.mw.protocol.p206V1_0_0.parse.global.GlCreate; import com.dy.common.threadPool.ThreadPool; import com.dy.common.util.ByteUtil; import com.dy.testClient.ServerProperties; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.apache.mina.core.session.IoSession; public class MyThreadJob implements ThreadPool.Job { private static final Logger log = LogManager.getLogger(MyThreadJob.class) ; public String rtuAddr; public String serverIp; public Integer serverPort; public IoSession session ; public boolean exceptionOnConnect = false ; public static final int connectTimeout = 3000 ; public int sendTimes = 1 ;//发送数据次数 public int heartbeatTimes = 1 ;//上报心跳次数 public long overStart = 0L; public boolean isOver = false ; public MyThreadJob(){ } public MyThreadJob(String rtuAddr, String serverIp, Integer serverPort){ this.rtuAddr = rtuAddr ; this.serverIp = serverIp ; this.serverPort = serverPort ; } @Override public void execute() throws Exception { if(!this.isOver){ if(session != null){ if(sendTimes <= ServerProperties.sendTimes){ log.info("RTU" + rtuAddr + "开始任务"); log.info("RTU" + rtuAddr + "将要执行" + ServerProperties.sendTimes + "轮次任务,当前轮次是" + sendTimes); sendDataOfP206V1_0_0() ; }else{ if(ServerProperties.sendOverThenCloseConnect == 1){ log.info("RTU" + rtuAddr + "等待一会,以接收通信中间件下行数据"); if(overStart == 0){ overStart = System.currentTimeMillis() ; }else{ long now = System.currentTimeMillis() ; if(now - overStart >= 30 * 1000){ this.jobOver() ; } } }else{ this.jobOver() ; } } } } } private void sendDataOfP206V1_0_0(){ try{ if(heartbeatTimes > ServerProperties.heartbeatTimes){ heartbeatTimes = 1 ; this.sendReportData() ; TcpClUnit.clientSendData(); sendTimes++ ; }else{ this.sendHeartbeat() ; TcpClUnit.clientSendData(); heartbeatTimes++ ; } }catch(Exception e){ e.printStackTrace(); } } private void sendHeartbeat(){ try{ byte[] bs = this.createHeartbeat() ; this.session.write(bs) ; log.info("RTU" + rtuAddr + "发送了心跳数据:" + ByteUtil.bytes2Hex(bs, false)); }catch (Exception e){ e.printStackTrace(); } } private void sendReportData(){ try{ byte[] bs = this.createReport() ; this.session.write(bs) ; log.info("RTU" + rtuAddr + "发送了上报数据:" + ByteUtil.bytes2Hex(bs, false)); }catch (Exception e){ e.printStackTrace(); } } private void jobOver(){ if(ServerProperties.sendOverThenCloseConnect == 1){ session.closeOnFlush() ; } this.isOver = true ; TcpClUnit.clientOver() ; } /** * 构造心跳数据 * @return 字节数组 * @throws Exception 异常 */ public byte[] createHeartbeat( ) throws Exception { CommonV1_0_1 commonV1_0_1 = new CommonV1_0_1() ; byte[] bytes ; byte[] bsHead = new byte[ProtocolConstantV206V1_0_0.lenHead2Code] ; byte index = 0 ; bsHead[index] = ProtocolConstantV206V1_0_0.P_Head_Byte ; index++ ; bsHead[index] = 0 ;//帧长度 index++ ; bsHead[index] = ProtocolConstantV206V1_0_0.P_Head_Byte ; index++ ; bsHead[index] = commonV1_0_1.createCtrl((byte)0x80, (byte)0) ;//控制域功能码:确认 认可 index++ ; GlCreate.createRtuAddr(this.rtuAddr, bsHead, index); index += 5 ; ByteUtil.hex2Bytes("02", bsHead, index) ; byte[] bs = new byte[1] ; bs[0] = (byte)0xF2 ;//数据域: 1 个字节,F0 登录, F1 退出登录,F2 在线保持。 bytes = ByteUtil.bytesMerge(bsHead, bs) ; GlCreate.createLen(bytes);//长度放字节数组中 byte[] bsTail = GlCreate.createCrcTail(bytes) ;//CRC和尾叠加字节数组中 bytes = ByteUtil.bytesMerge(bytes, bsTail) ; return bytes ; } /** * 构造上报数据 * @return 字节数组 * @throws Exception 异常 */ public byte[] createReport( ) throws Exception { CommonV1_0_1 commonV1_0_1 = new CommonV1_0_1() ; byte[] bytes ; byte[] bsHead = new byte[ProtocolConstantV206V1_0_0.lenHead2Code] ; byte index = 0 ; bsHead[index] = ProtocolConstantV206V1_0_0.P_Head_Byte ; index++ ; bsHead[index] = 0 ;//帧长度 index++ ; bsHead[index] = ProtocolConstantV206V1_0_0.P_Head_Byte ; index++ ; bsHead[index] = commonV1_0_1.createCtrl((byte)0x80, (byte)3) ;//控制域功能码3:自报帧,流量(水量)参数 index++ ; GlCreate.createRtuAddr(this.rtuAddr, bsHead, index); index += 5 ; ByteUtil.hex2Bytes("C0", bsHead, index) ; byte[] bs = new byte[2] ; bs[0] = (byte)0x04 ;//有流量数据 bs[1] = (byte)0xE0 ;//有水压、电池电压、信号强度 bytes = ByteUtil.bytesMerge(bsHead, bs) ; bs = new byte[5] ;//瞬时流量 bs[0] = ByteUtil.int2BCD_LE (21)[0] ; bs[1] = ByteUtil.int2BCD_LE (43)[0] ; bs[2] = ByteUtil.int2BCD_LE (65)[0] ; bytes = ByteUtil.bytesMerge(bytes, bs) ; bs = new byte[5] ;//累计流量 bs[0] = ByteUtil.int2BCD_LE (21)[0] ; bs[1] = ByteUtil.int2BCD_LE (43)[0] ; bs[2] = ByteUtil.int2BCD_LE (65)[0] ; bs[3] = ByteUtil.int2BCD_LE (87)[0] ; bytes = ByteUtil.bytesMerge(bytes, bs) ; bs = new byte[5] ;//损失流量 bs[0] = ByteUtil.int2BCD_LE (10)[0] ; bs[1] = ByteUtil.int2BCD_LE (32)[0] ; bs[2] = ByteUtil.int2BCD_LE (54)[0] ; bytes = ByteUtil.bytesMerge(bytes, bs) ; bs = new byte[4] ;//水压 bs[0] = ByteUtil.int2BCD_LE (10)[0] ; bs[1] = ByteUtil.int2BCD_LE (32)[0] ; bs[2] = ByteUtil.int2BCD_LE (4)[0] ; bytes = ByteUtil.bytesMerge(bytes, bs) ; bs = new byte[4] ;//电池电压 bs[0] = ByteUtil.int2BCD_LE (10)[0] ; bs[1] = ByteUtil.int2BCD_LE (32)[0] ; bs[2] = ByteUtil.int2BCD_LE (10)[0] ; bs[3] = ByteUtil.int2BCD_LE (32)[0] ; bytes = ByteUtil.bytesMerge(bytes, bs) ; bs = new byte[1] ;//信号强度 bs[0] = ByteUtil.int2BCD_LE (21)[0] ; bytes = ByteUtil.bytesMerge(bytes, bs) ; bs = new byte[6] ;//时钟 GlCreate.createTp(bs, 0); bytes = ByteUtil.bytesMerge(bytes, bs) ; GlCreate.createLen(bytes);//长度放字节数组中 byte[] bsTail = GlCreate.createCrcTail(bytes) ;//CRC和尾叠加字节数组中 bytes = ByteUtil.bytesMerge(bytes, bsTail) ; return bytes ; } @Override public void destroy() { } @Override public boolean isDestroy() { return false; } }