在使用HSF框架提供服务时,直接使用RpcContext.getContext().getRemoteAddress()获取调用方IP地址经常返回空值。这是因为HSF框架在服务提供方默认不记录调用方IP。本文将提供解决此问题的有效方案。
问题分析:
提供的代码片段展示了服务提供方尝试使用RpcContext.getContext().getRemoteAddress()获取IP,但结果为空。RpcContext类来自edas-sdk-1.8.3.jar,其getRemoteAddress()方法返回InetSocketAddress对象,在服务提供方通常未被自动填充。
解决方案:通过自定义Attachment传递IP地址
最可靠的方案是通过HSF框架的Attachment机制在调用方设置IP地址,然后在服务提供方获取。
服务提供方代码 (YwcxServiceImpl):
@Slf4j @HsfProvider(serviceInterface = YwcxService.class, serviceVersion = "1.0.0") public class YwcxServiceImpl implements YwcxService { @Override public String inster(List<YwcxQuery> ywcxquerylist) { String remoteIp = RpcContext.getContext().getAttachment("remoteIp"); log.info("Remote IP: {}", remoteIp); // 业务逻辑... return "success"; // or other return value } }
服务调用方代码 (服务B):
@Scheduled(cron = "${task.cron.runTaskHuayu}") public String dsrw() { // 获取调用方IP地址 (需要根据实际情况替换获取IP的方法) String callerIp = getCallerIpAddress(); RpcContext.getContext().setAttachment("remoteIp", callerIp); return ywcxService.inster(fqxcsqquerylist); } // 获取调用方IP地址的方法,需要根据实际环境实现 private String getCallerIpAddress() { // 例如,使用HttpServletRequest获取IP // 或者使用其他方法获取本机IP // 这里需要根据你的具体应用场景来实现 return "127.0.0.1"; // 替换为实际获取IP地址的代码 }
关键改进:
通过这种方法,即使RpcContext.getContext().getRemoteAddress()返回空,也能可靠地获取调用方的IP地址。 记住替换getCallerIpAddress()方法中的占位符代码为实际获取IP的逻辑。
以上就是在HSF框架中如何解决RpcContext.getContext().getRemoteAddress()返回空的问题?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号