CZT
2023-10-21 3e7773504d6bd15e6ed20ecf5c6236b163ba0fe8
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
package com.ld.igds.protocol.bhzn.inout.client;
 
import com.ld.igds.util.BytesUtil;
import io.netty.channel.ChannelHandlerContext;
import io.netty.channel.SimpleChannelInboundHandler;
import io.netty.util.internal.logging.InternalLogger;
import io.netty.util.internal.logging.InternalLoggerFactory;
 
import java.net.InetSocketAddress;
 
/**
 * Handles a client-side channel.
 */
 
public class ClientHandler extends SimpleChannelInboundHandler<Object> {
    private final InternalLogger log = InternalLoggerFactory.getInstance(this
            .getClass());
    @Override
    public void channelActive(ChannelHandlerContext ctx) {
        InetSocketAddress insocket = (InetSocketAddress) ctx.channel()
                .remoteAddress();
        log.info("出入库控制器成功连接,IP={},port={}", insocket.getAddress()
                .getHostAddress(), insocket.getPort());
    }
 
    @Override
    public void channelInactive(ChannelHandlerContext ctx) throws Exception {
        super.channelInactive(ctx);
 
        InetSocketAddress insocket = (InetSocketAddress) ctx.channel()
                .remoteAddress();
 
        log.info("出入库控制器断开连接,IP={},port={}", insocket.getAddress(),insocket.getPort());
    }
 
    @Override
    public void channelRead0(ChannelHandlerContext ctx, Object msg)
            throws Exception {
        byte[] bytes = (byte[]) msg;
 
        log.info("出入库控制器返回信息=" + BytesUtil.bytesToString(bytes));
 
        InetSocketAddress insocket = (InetSocketAddress) ctx.channel()
                .remoteAddress();
    }
 
    @Override
    public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) {
        ctx.close();
    }
 
}