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