Netty服务端如何稳定获取客户端IP地址,即使客户端端口每次连接都变化?

Netty服务端如何稳定获取客户端IP地址,即使客户端端口每次连接都变化?

Netty服务端:如何可靠获取客户端IP地址,即使端口动态变化?

在使用Netty构建Java服务端时,获取客户端IP地址和端口号至关重要,例如用于连接管理。然而,客户端IP保持不变,端口却每次连接都变化的情况,常常困扰开发者。本文将分析此问题,并提供解决方案。

代码示例展示了Netty服务端获取并存储客户端IP和端口的逻辑:通过channel.remoteAddress()获取客户端地址,并将其存储在remoteAddressChannelMap中。

/**  * 客户端连接时执行  * 1. 打印连接信息  * 2. 存储客户端IP和连接通道到remoteAddressChannelMap  */ @Override public void handlerAdded(ChannelHandlerContext ctx) throws Exception {     Channel channel = ctx.channel();     InetSocketAddress remoteAddress = (InetSocketAddress) channel.remoteAddress();     System.err.println("新客户端连接:"+ channel.remoteAddress());     // 提取IP地址,忽略端口号     String clientIp = remoteAddress.getAddress().getHostAddress();     remoteAddressChannelMap.put(clientIp, channel);     System.out.println("remoteAddressChannelMap size: " + remoteAddressChannelMap.size()); }

代码运行后,客户端IP地址不变,但端口号每次都不同。这并非代码错误,而是操作系统动态分配端口的正常行为。

客户端IP地址由网络配置决定,而端口号则由操作系统动态分配,连接断开后释放。因此,即使netstat命令在连接前未显示端口占用,连接建立后该端口即被占用。这是为了保证多个应用同时进行网络通信。 只有在连接保持期间使用netstat才能看到端口占用情况。

上述代码修改后的版本,直接提取IP地址,避免了端口号变化带来的问题,从而实现了稳定获取客户端IP地址的目的。

© 版权声明
THE END
喜欢就支持一下吧
点赞15 分享