From 7bf5118a11887f9862e9e7fe8a9e57c3eef5c328 Mon Sep 17 00:00:00 2001 From: xuyuefeng Date: Tue, 13 Jan 2026 08:16:46 +0000 Subject: [PATCH] =?UTF-8?q?!253=20refactor=20=E4=BC=98=E5=8C=96=20InetUtil?= =?UTF-8?q?sProperties=20=E7=9A=84=E7=BB=91=E5=AE=9A=E9=80=BB=E8=BE=91?= =?UTF-8?q?=EF=BC=8C=E9=81=BF=E5=85=8D=E6=97=A9=E6=9C=9F=E5=88=9D=E5=A7=8B?= =?UTF-8?q?=E5=8C=96=E9=97=AE=E9=A2=98=20*=20refactor=20=E4=BC=98=E5=8C=96?= =?UTF-8?q?=20InetUtilsProperties=20=E7=9A=84=E7=BB=91=E5=AE=9A=E9=80=BB?= =?UTF-8?q?=E8=BE=91=EF=BC=8C=E9=81=BF=E5=85=8D=E6=97=A9=E6=9C=9F=E5=88=9D?= =?UTF-8?q?=E5=A7=8B=E5=8C=96=E9=97=AE=E9=A2=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../CustomBeanFactoryPostProcessor.java | 37 +++++++++++++------ 1 file changed, 25 insertions(+), 12 deletions(-) diff --git a/ruoyi-common/ruoyi-common-dubbo/src/main/java/org/dromara/common/dubbo/config/CustomBeanFactoryPostProcessor.java b/ruoyi-common/ruoyi-common-dubbo/src/main/java/org/dromara/common/dubbo/config/CustomBeanFactoryPostProcessor.java index 96bdb5158..a4aefa7c8 100644 --- a/ruoyi-common/ruoyi-common-dubbo/src/main/java/org/dromara/common/dubbo/config/CustomBeanFactoryPostProcessor.java +++ b/ruoyi-common/ruoyi-common-dubbo/src/main/java/org/dromara/common/dubbo/config/CustomBeanFactoryPostProcessor.java @@ -5,11 +5,10 @@ import org.dromara.common.core.utils.StringUtils; import org.springframework.beans.BeansException; import org.springframework.beans.factory.config.BeanFactoryPostProcessor; import org.springframework.beans.factory.config.ConfigurableListableBeanFactory; -import org.springframework.boot.context.properties.bind.Bindable; import org.springframework.boot.context.properties.bind.Binder; -import org.springframework.boot.context.properties.source.ConfigurationPropertySources; import org.springframework.cloud.commons.util.InetUtils; import org.springframework.cloud.commons.util.InetUtilsProperties; +import org.springframework.context.EnvironmentAware; import org.springframework.core.Ordered; import org.springframework.core.env.Environment; @@ -21,7 +20,20 @@ import java.net.InetAddress; * * @author Lion Li */ -public class CustomBeanFactoryPostProcessor implements BeanFactoryPostProcessor, Ordered { +public class CustomBeanFactoryPostProcessor implements BeanFactoryPostProcessor, Ordered, EnvironmentAware { + + private Environment environment; + + /** + * 设置此组件运行的应用环境。 + * 由 Spring 容器回调注入。 + * + * @param environment 当前应用环境对象 + */ + @Override + public void setEnvironment(Environment environment) { + this.environment = environment; + } /** * 获取该 BeanFactoryPostProcessor 的顺序,确保它在容器初始化过程中具有最高优先级 @@ -45,13 +57,14 @@ public class CustomBeanFactoryPostProcessor implements BeanFactoryPostProcessor, if (StringUtils.isNotBlank(property)) { return; } - // 获取 InetUtils bean,用于获取 IP 地址 - Environment environment = beanFactory.getBean(Environment.class); - InetUtilsProperties target = new InetUtilsProperties(); - ConfigurationPropertySources.attach(environment); - Binder.get(environment).bind(InetUtilsProperties.PREFIX, Bindable.ofInstance(target)); - String ip = "127.0.0.1"; - try (InetUtils inetUtils = new InetUtils(target)) { + // 手动绑定 InetUtilsProperties,避免早期初始化导致配置未注入 + InetUtilsProperties properties = Binder.get(environment) + .bind(InetUtilsProperties.PREFIX, InetUtilsProperties.class) + .orElseGet(InetUtilsProperties::new); + + // 创建临时的 InetUtils 实例 + try (InetUtils inetUtils = new InetUtils(properties)) { + String ip = "127.0.0.1"; // 获取第一个非回环地址 InetAddress address = inetUtils.findFirstNonLoopbackAddress(); if (address != null) { @@ -68,8 +81,8 @@ public class CustomBeanFactoryPostProcessor implements BeanFactoryPostProcessor, ip = inetUtils.findFirstNonLoopbackHostInfo().getIpAddress(); } } + // 设置系统属性 DUBBO_IP_TO_REGISTRY 为获取到的 IP 地址 + System.setProperty(CommonConstants.DubboProperty.DUBBO_IP_TO_REGISTRY, ip); } - // 设置系统属性 DUBBO_IP_TO_REGISTRY 为获取到的 IP 地址 - System.setProperty(CommonConstants.DubboProperty.DUBBO_IP_TO_REGISTRY, ip); } }