From c2976b80e8850be2d28dc2132c6659856b871f3c Mon Sep 17 00:00:00 2001 From: zhubaomin <zhubaomin> Date: 星期四, 08 五月 2025 21:10:42 +0800 Subject: [PATCH] Merge branch 'master' of http://8.140.179.55:20000/r/pipIrr-SV --- pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/channel/tcp/DataCodecFactory.java | 39 +++++++++++++++++++++++++++++++++++++++ 1 files changed, 39 insertions(+), 0 deletions(-) diff --git a/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/channel/tcp/DataCodecFactory.java b/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/channel/tcp/DataCodecFactory.java new file mode 100644 index 0000000..284dcb6 --- /dev/null +++ b/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/channel/tcp/DataCodecFactory.java @@ -0,0 +1,39 @@ +package com.dy.common.mw.channel.tcp; + +import org.apache.mina.filter.codec.ProtocolCodecFactory; +import org.apache.mina.filter.codec.ProtocolEncoder; +import org.apache.mina.filter.codec.ProtocolDecoder; +import org.apache.mina.core.session.IoSession; + +public class DataCodecFactory implements ProtocolCodecFactory { + + private TcpUnitAdapter adapter ; + private boolean stop = false ;//涓簍rue鏃讹紝鍋滄TCP鏈嶅姟锛屽苟鎶婂凡缁廡CP杩炴帴鏂繛鎺� + + public DataCodecFactory(TcpUnitAdapter adapter) { + this.adapter = adapter ; + } + + public void stop(){ + stop = true ; + } + + public void recover(){ + this.stop = false ; + } + + + public ProtocolEncoder getEncoder(IoSession ioSession) { + if(stop){ + ioSession.closeNow() ; + } + return new DataEncoder(); + } + + public ProtocolDecoder getDecoder(IoSession ioSession) { + if(stop){ + ioSession.closeNow() ; + } + return new DataDecoder(adapter.newPrefixedDataAvailableHandle()); + } +} -- Gitblit v1.8.0