辛星netty4.1教程第二篇:区分不同的客户端

本文介绍了如何在Netty服务端通过ChannelHandlerContext获取连接ID区分不同客户端,并通过实现用户状态保存功能,展示了在长连接应用中处理多个客户端连接的方法。示例代码展示了监听以'name'开头的消息来设置用户名,并在后续通信中携带该用户名。
摘要由CSDN通过智能技术生成

本教程源码托管在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
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值