io.netty
netty-all
4.1.20.Final
创建服务端的handler,主要是处理客户端提交的请求的。
package com.dpb.netty.tcp;
import io.netty.buffer.ByteBuf;
import io.netty.buffer.Unpooled;
import io.netty.channel.ChannelHandlerContext;
import io.netty.channel.ChannelInboundHandlerAdapter;
import io.netty.util.CharsetUtil;
/**
-
@program: netty4demo
-
@description:
-
@author: 波波烤鸭
-
@create: 2019-12-23 11:24
*/
public class NettyServerHandler extends ChannelInboundHandlerAdapter {
/**
-
读取客户端发送来的数据
-
@param ctx ChannelHandler的上下文对象 有管道 pipeline 通道 channel 和 请求地址 等信息
-
@param msg 客户端发送的具体数据
-
@throws Exception
*/
@Override
public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {
System.out.println(“客户端请求到了…” + ctx.channel().remoteAddress());
ByteBuf buf = (ByteBuf) msg;
System.out.println(“客户端发送的数据是:” +buf.toString(CharsetUtil.UTF_8));
}
/**
-
读取客户端发送数据完成后的方法
-
在本方法中可以发送返回的数据
-
@param ctx
-
@throws Exception
*/
@Override
public void channelReadComplete(ChannelHandlerContext ctx) throws Exception {
// writeAndFlush 是组合方法
ctx.writeAndFlush(Unpooled.copiedBuffer(“你好啊,客户端…_”,CharsetUtil.UTF_8));
}
}
创建服务端
package com.dpb.netty.simple;
import io.netty.bootstrap.ServerBootstrap;
import io.netty.channel.ChannelFuture;
import io.netty.channel.ChannelInitializer;
import io.netty.channel.ChannelOption;
import io.netty.channel.EventLoopGroup;
import io.netty.channel.nio.NioEventLoopGroup;
import io.netty.channel.socket.SocketChannel;
import io.netty.channel.socket.nio.NioServerSocketChannel;
/**
-
@program: netty4demo
-
@description:
-
@author: 波波烤鸭
-
@create: 2019-12-23 11:15
*/
public class NettyServerDemo {
public static void main(String[] args) {
// 创建对应的 线程池
// 创建Boss group
EventLoopGroup boosGroup = new NioEventLoopGroup(1);
// 创建 workgroup
EventLoopGroup workGroup = new NioEventLoopGroup();
// 创建对应的启动类
ServerBootstrap bootstrap = new ServerBootstrap();
try{
// 设置相关的配置信息
bootstrap.group(boosGroup,workGroup) // 设置对应的线程组
.channel(NioServerSocketChannel.class) // 设置对应的通道
.option(ChannelOption.SO_BACKLOG,1024) // 设置线程的连接个数
.childHandler(new ChannelInitializer() { // 设置
/**
-
给pipeline 设置处理器
-
@param socketChannel
-
@throws Exception
*/
@Override
protected void initChannel(SocketChannel socketChannel) throws Exception {
socketChannel.pipeline().addLast(new NettyServerHandler());
}
});
System.out.println(“服务启动了…”);
// 绑定端口 启动服务
ChannelFuture channelFuture = bootstrap.bind(6668).sync();
// 对关闭通道进行监听
channelFuture.channel().closeFuture().sync();
}catch (Exception e){
}finally {
// 优雅停服
boosGroup.shutdownGracefully();
workGroup.shutdownGracefully();
}
}
}
客户端handler主要是发送请求给客户端及处理服务端返回的信息。
package com.dpb.netty.simple;
import io.netty.buffer.ByteBuf;
import io.netty.buffer.Unpooled;
import io.netty.channel.ChannelHandlerContext;
import io.netty.channel.ChannelInboundHandlerAdapter;
import io.netty.util.CharsetUtil;
/**
-
@program: netty4demo
-
@description:
-
@author: 波波烤鸭
-
@create: 2019-12-23 11:36
*/
public class NettyClientHandler extends ChannelInboundHandlerAdapter {
/**
-
连接上服务的回调方法
-
@param ctx
-
@throws Exception
*/
@Override
public void channelActive(
《一线大厂Java面试题解析+后端开发学习笔记+最新架构讲解视频+实战项目源码讲义》
【docs.qq.com/doc/DSmxTbFJ1cmN1R2dB】 完整内容开源分享
ChannelHandlerContext ctx) throws Exception {
// 发送数据
System.out.println(“连接上了 服务器…”);
ctx.writeAndFlush(Unpooled.copiedBuffer(“哈哈 你好呀!!!”, CharsetUtil.UTF_8));
}
/**
-
读取服务端返回的信息
-
@param ctx
-
@param msg
-
@throws Exception
*/
@Override
public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {
ByteBuf buf = (ByteBuf) msg;
System.out.println(“服务端返回的信息:” + buf.toString(CharsetUtil.UTF_8));
}
}
客户端用来连接服务器
package com.dpb.netty.simple;
import io.netty.bootstrap.Bootstrap;
import io.netty.channel.ChannelFuture;
import io.netty.channel.ChannelInitializer;
import io.netty.channel.EventLoopGroup;
import io.netty.channel.nio.NioEventLoopGroup;
import io.netty.channel.socket.SocketChannel;