博客
关于我
Netty4服务端入门代码示例
阅读量:331 次
发布时间:2019-03-04

本文共 2453 字,大约阅读时间需要 8 分钟。

添加Maven依赖

        <dependency>            <groupId>io.netty</groupId>            <artifactId>netty-all</artifactId>            <version>4.1.36.Final</version>        </dependency>

代码示例:

import io.netty.bootstrap.ServerBootstrap;import io.netty.channel.*;import io.netty.channel.nio.NioEventLoopGroup;import io.netty.channel.socket.SocketChannel;import io.netty.channel.socket.nio.NioServerSocketChannel;import io.netty.handler.codec.string.StringDecoder;import io.netty.handler.codec.string.StringEncoder;public class NetttyServer{    public static void main(String[] args)    {        EventLoopGroup boss = new NioEventLoopGroup();        EventLoopGroup worker = new NioEventLoopGroup();        ServerBootstrap bootstrap = new ServerBootstrap();        bootstrap.group(boss,worker)                .channel(NioServerSocketChannel.class)                .childHandler(new ChannelInitializer<SocketChannel>()                {                    @Override                    protected void initChannel(SocketChannel socketChannel) throws Exception                    {                        socketChannel.pipeline()                                .addLast("encoder",new StringEncoder())                                .addLast("decoder",new StringDecoder())                                .addLast("hello world hanlder",new HelloWorldHandler());                    }                });        try        {            ChannelFuture channelFuture = bootstrap.bind(8080).sync();            channelFuture.channel().closeFuture().sync();        } catch (InterruptedException e){            e.printStackTrace();        }finally        {            boss.shutdownGracefully();            worker.shutdownGracefully();        }    }    static class HelloWorldHandler extends ChannelInboundHandlerAdapter    {        @Override        public void channelActive(ChannelHandlerContext ctx) throws Exception        {            System.out.println("channel Active and write back......");            String resp = "Hello world";            ChannelFuture future = ctx.channel().writeAndFlush(resp);            future.sync();            System.out.println("success:"+future.isSuccess());            //super.channelActive(ctx);        }        public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {            System.out.println("read msg : "+msg);            String resp = "Hello world";            ctx.channel().writeAndFlush(resp);        }    }}

转载地址:http://qume.baihongyu.com/

你可能感兴趣的文章
【python】理解列表推导式以及列表推导式嵌套
查看>>
pythonBug入门——从零开始学python
查看>>
Vue.js——v-model结合checkbox类型——2020.11.22
查看>>
Mybatis核心配置文件--常用标签详解
查看>>
R语言练习题答案(3)
查看>>
jQuery 事件及动画
查看>>
[电影]《Ladybird》演绎完整18岁的青春
查看>>
树莓派博通BCM2835芯片的IO口驱动代码调试和测试
查看>>
js中[]、{}、()的区别
查看>>
js-禁止右键菜单代码、禁止复制粘贴代码
查看>>
血色先锋队
查看>>
win10系统安装配置Go环境包(第0章)
查看>>
搭建samba服务器
查看>>
Java: 错误: 不支持发行版本 5
查看>>
顺序表的操作总结
查看>>
Java基础语法
查看>>
原创-开发问题指南
查看>>
文本情感分类
查看>>
Python模块_os文件_目录方法
查看>>
部署kuboard3 管理工具
查看>>