免费的app推广平台,潍坊市网站优化,免费纯ftp空间,广州市海珠区建设和市政局网站小傅哥 | https://bugstack.cn 沉淀、分享、成长#xff0c;让自己和他人都能有所收获。专注于原创专题案例编写#xff0c;目前已完成的专题有#xff1b;Netty4.x实战专题案例、用Java实现JVM、基于JavaAgent的全链路监控、手写RPC框架、架构设计专题案例、源码分析等。你…小傅哥 | https://bugstack.cn 沉淀、分享、成长让自己和他人都能有所收获。专注于原创专题案例编写目前已完成的专题有Netty4.x实战专题案例、用Java实现JVM、基于JavaAgent的全链路监控、手写RPC框架、架构设计专题案例、源码分析等。你用剑 、我用刀 好的代码都很烧望你不吝出招一、前言介绍 Netty开发中客户端与服务端需要保持同样的半包粘包处理编码解码处理、收发数据方式这样才能保证数据通信正常。在前面NettyServer的章节中我们也同样处理了半包粘包、编码解码等为此在本章节我们可以把这些知识模块开发到NettyClient中。本章节涉及到的知识点有LineBasedFrameDecoder、StringDecoder、StringEncoder、ChannelInboundHandlerAdapter等。二、开发环境 jdk1.8【jdk1.7以下只能部分支持netty】Netty4.1.36.Final【netty3.x 4.x 5每次的变化较大接口类名也随着变化】telnet 测试【可以现在你的win7机器上测试这个命令用于链接到服务端的测试命令】三、代码示例 itstack-demo-netty-1-08
└── src├── main│ └── java│ └── org.itstack.demo.netty.client│ ├── MyChannelInitializer.java│ ├── MyClientHandler.java│ └── NettyClient.java└── test└── java└── org.itstack.demo.netty.test└── ApiTest.javaMyChannelInitializer.java/*** 虫洞栈https://bugstack.cn* 公众号bugstack虫洞栈 获取学习源码* Create by fuzhengwei on 2019*/
public class MyChannelInitializer extends ChannelInitializerSocketChannel {Overrideprotected void initChannel(SocketChannel channel) throws Exception {// 基于换行符号channel.pipeline().addLast(new LineBasedFrameDecoder(1024));// 解码转String注意调整自己的编码格式GBK、UTF-8channel.pipeline().addLast(new StringDecoder(Charset.forName(GBK)));// 解码转String注意调整自己的编码格式GBK、UTF-8channel.pipeline().addLast(new StringEncoder(Charset.forName(GBK)));// 在管道中添加我们自己的接收数据实现方法channel.pipeline().addLast(new MyClientHandler());}}MyClientHandler.java/*** 虫洞栈https://bugstack.cn* 公众号bugstack虫洞栈 获取学习源码* Create by fuzhengwei on 2019*/
public class MyClientHandler extends ChannelInboundHandlerAdapter {/*** 当客户端主动链接服务端的链接后这个通道就是活跃的了。也就是客户端与服务端建立了通信通道并且可以传输数据*/Overridepublic void channelActive(ChannelHandlerContext ctx) throws Exception {SocketChannel channel (SocketChannel) ctx.channel();System.out.println(链接报告开始);System.out.println(链接报告信息本客户端链接到服务端。channelId channel.id());System.out.println(链接报告IP: channel.localAddress().getHostString());System.out.println(链接报告Port: channel.localAddress().getPort());System.out.println(链接报告完毕);//通知客户端链接建立成功String str 通知服务端链接建立成功 new Date() channel.localAddress().getHostString() rn;ctx.writeAndFlush(str);}/*** 当客户端主动断开服务端的链接后这个通道就是不活跃的。也就是说客户端与服务端的关闭了通信通道并且不可以传输数据*/Overridepublic void channelInactive(ChannelHandlerContext ctx) throws Exception {System.out.println(断开链接 ctx.channel().localAddress().toString());}Overridepublic void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {//接收msg消息{与上一章节相比此处已经不需要自己进行解码}System.out.println(new SimpleDateFormat(yyyy-MM-dd HH:mm:ss).format(new Date()) 接收到消息 msg);//通知客户端链消息发送成功String str 客户端收到 new Date() msg rn;ctx.writeAndFlush(str);}/*** 抓住异常当发生异常的时候可以做一些相应的处理比如打印日志、关闭链接*/Overridepublic void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {ctx.close();System.out.println(异常信息rn cause.getMessage());}}NettyClient.java/*** 虫洞栈https://bugstack.cn* 公众号bugstack虫洞栈 获取学习源码* Create by fuzhengwei on 2019*/
public class NettyClient {public static void main(String[] args) {new NettyClient().connect(127.0.0.1, 7397);}private void connect(String inetHost, int inetPort) {EventLoopGroup workerGroup new NioEventLoopGroup();try {Bootstrap b new Bootstrap();b.group(workerGroup);b.channel(NioSocketChannel.class);b.option(ChannelOption.AUTO_READ, true);b.handler(new MyChannelInitializer());ChannelFuture f b.connect(inetHost, inetPort).sync();System.out.println(itstack-demo-netty client start done. {关注公众号bugstack虫洞栈获取源码});f.channel().closeFuture().sync();} catch (InterruptedException e) {e.printStackTrace();} finally {workerGroup.shutdownGracefully();}}}四、测试结果 启动模拟器NetAssist 设置TCP Server启动客户端NettyClient执行结果/*** 虫洞栈https://bugstack.cn* 公众号bugstack虫洞栈 获取学习源码* Create by fuzhengwei on 2019*/
public class NettyClient {public static void main(String[] args) {new NettyClient().connect(127.0.0.1, 7397);}private void connect(String inetHost, int inetPort) {EventLoopGroup workerGroup new NioEventLoopGroup();try {Bootstrap b new Bootstrap();b.group(workerGroup);b.channel(NioSocketChannel.class);b.option(ChannelOption.AUTO_READ, true);b.handler(new MyChannelInitializer());ChannelFuture f b.connect(inetHost, inetPort).sync();System.out.println(itstack-demo-netty client start done. {关注公众号bugstack虫洞栈获取源码});f.channel().closeFuture().sync();} catch (InterruptedException e) {e.printStackTrace();} finally {workerGroup.shutdownGracefully();}}}