parent
897f6c094b
commit
d5408506d8
@ -0,0 +1,81 @@
|
|||||||
|
package com.msb.socket;/**
|
||||||
|
* @Author bingor
|
||||||
|
* @Date 2022/11/16 13:39
|
||||||
|
* @Description: com.msb.socket
|
||||||
|
* @Version: 1.0
|
||||||
|
*/
|
||||||
|
|
||||||
|
import io.netty.bootstrap.Bootstrap;
|
||||||
|
import io.netty.buffer.ByteBuf;
|
||||||
|
import io.netty.channel.*;
|
||||||
|
import io.netty.channel.nio.NioEventLoopGroup;
|
||||||
|
import io.netty.channel.socket.SocketChannel;
|
||||||
|
import io.netty.channel.socket.nio.NioSocketChannel;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*@ClassName Client
|
||||||
|
*@Description TODO
|
||||||
|
*@Author bingor
|
||||||
|
*@Date 2022/11/16 13:39
|
||||||
|
*@Version 3.0
|
||||||
|
*/
|
||||||
|
public class Client {
|
||||||
|
|
||||||
|
public void connect() {
|
||||||
|
//线程池
|
||||||
|
EventLoopGroup group = new NioEventLoopGroup(1);
|
||||||
|
Bootstrap bootstrap = new Bootstrap();
|
||||||
|
|
||||||
|
try {
|
||||||
|
ChannelFuture future = bootstrap.group(group)
|
||||||
|
.channel(NioSocketChannel.class)
|
||||||
|
.handler(new ClientChannelInitializer())
|
||||||
|
.connect("localhost", 8888);
|
||||||
|
|
||||||
|
future.addListener(new ChannelFutureListener() {
|
||||||
|
@Override
|
||||||
|
public void operationComplete(ChannelFuture channelFuture) throws Exception {
|
||||||
|
if(channelFuture.isSuccess()) {
|
||||||
|
System.out.println("connected!");
|
||||||
|
} else {
|
||||||
|
System.out.println("not connect!");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
future.sync();
|
||||||
|
|
||||||
|
future.channel().closeFuture().sync();
|
||||||
|
|
||||||
|
} catch (InterruptedException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
} finally {
|
||||||
|
group.shutdownGracefully();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
Client client = new Client();
|
||||||
|
client.connect();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
class ClientChannelInitializer extends ChannelInitializer<SocketChannel> {
|
||||||
|
@Override
|
||||||
|
protected void initChannel(SocketChannel socketChannel) throws Exception {
|
||||||
|
socketChannel.pipeline().addLast(new ClientHandler());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class ClientHandler extends ChannelInboundHandlerAdapter {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {
|
||||||
|
// super.channelRead(ctx, msg);
|
||||||
|
ByteBuf buf = (ByteBuf) msg;
|
||||||
|
byte[] bytes = new byte[buf.readableBytes()];
|
||||||
|
buf.getBytes(buf.readerIndex(), bytes);
|
||||||
|
System.out.println(new String(bytes));
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in new issue