本教程源码托管在github上,地址: https://github.com/xinxing0913/netty-demo 。
有什么不清楚的可以加我微信:xinxing0913,备注”netty交流”就可以啦。
因为我们用netty写服务端代码的时候,一般我们都是编写的长连接应用,也就是我们是保存了客户端的状态的,这和写stateless的接口应用是完全不相同的体验,跟写通过Cookie和session来保存状态的http应用有些相似。
如果我们想为多个用户保存状态,我们应该怎么做呢?首先我们应该有能力来区分不同的连接,也就是我们可以获取到连接的id,这个id我们怎么获取呢,我们可以通过ChannelHandlerContext的channel()方法来获取它的id,然后我们调用它的asShortText()方法或者asLongText()方法来区分就可以啦。
由于我们这个范例不会涉及到太多的连接,所以我们使用asShortText()方法就可以了,这是一个字符串的哈希值,不同的连接都不相同。
下面我们来编写一个应用,我们的客户端通过namexxx来请求我们的服务器的时候,我们就给这个客户端设置对应的用户名为xxx,在这之后,我们在给客户端发消息的时候,我们都带上用户名。我们来看一下我们的Server类把,代码如下:
package com.mengzhidu.netty.demo.demo2;
import io.netty.bootstrap.ServerBootstrap;
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;
import io.netty.channel.socket.nio.NioServerSocketChannel;
import io.netty.handler.codec.LineBasedFrameDecoder;
import io.netty.handler.codec.string.StringDecoder;
import io.netty.handler.codec.string.StringEncoder;
import io.nett