SimpleChannelInboundHandler从不触发channelRead0

时间:2019-06-29 21:36:33

标签: java server netty

有一天,我决定使用Tcp协议创建一个Netty Chat服务器。当前,它成功记录了连接和断开连接,但是从不触发我的处理程序中的channelRead0。我尝试了Python客户端。 网络版本:4.1.6.Final

处理程序代码:

public class ServerWrapperHandler extends SimpleChannelInboundHandler<String> {

    private final TcpServer server;

    public ServerWrapperHandler(TcpServer server){

        this.server = server;
    }

    @Override
    public void handlerAdded(ChannelHandlerContext ctx) {
        System.out.println("Client connected.");
        server.addClient(ctx);
    }

    @Override
    public void handlerRemoved(ChannelHandlerContext ctx) {
        System.out.println("Client disconnected.");
        server.removeClient(ctx);
    }

    @Override
    public void channelRead0(ChannelHandlerContext ctx, String msg) {
        System.out.println("Message received.");
        server.handleMessage(ctx, msg);
    }

    @Override
    public void channelReadComplete(ChannelHandlerContext ctx) throws Exception {
        System.out.println("Read complete.");
        super.channelReadComplete(ctx);
    }

    @Override
    public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) {
        cause.printStackTrace();
        ctx.close();
    }
}

输出:

[TCPServ] Starting on 0.0.0.0:1052
Client connected.
Read complete.
Read complete.
Client disconnected.

客户代码:

import socket
conn = socket.socket()
conn.connect(("127.0.0.1", 1052))
conn.send("Hello")
tmp = conn.recv(1024)
while tmp:
    data += tmp
    tmp = conn.recv(1024)
print(data.decode("utf-8"))
conn.close()

1 个答案:

答案 0 :(得分:0)

顺便说一句,问题出在我的初始化程序中:我将DelimiterBasedFrameDecoder添加到我的管道中,并且该解码器正在停止线程。我不知道为什么,但是我不需要这个解码器,所以我删除了它,一切开始正常工作。

    @Override
    protected void initChannel(SocketChannel ch) throws Exception {
        // Create a default pipeline implementation.
        ChannelPipeline pipeline = ch.pipeline();

        // Protocol Decoder - translates binary data (e.g. ByteBuf) into a Java object.
        // Protocol Encoder - translates a Java object into binary data.

        // Add the text line codec combination first,
        pipeline.addLast("framer", new DelimiterBasedFrameDecoder(8192, Delimiters.lineDelimiter())); //<--- DELETE THIS
        pipeline.addLast("decoder", new StringDecoder());
        pipeline.addLast("encoder", new StringEncoder());
        pipeline.addLast("handler", new ServerWrapperHandler(tcpServer));
    }