From e58ac72bbbc14cfbd3d21dbcc3f1f55b3013bbb5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=99=B4=E9=9B=A8=E5=A4=9C?= <758366855@qq.com> Date: Fri, 4 Sep 2020 11:56:03 +0800 Subject: [PATCH] =?UTF-8?q?feat(SpringUtil):=20=E5=A2=9E=E5=8A=A0=E6=96=B0?= =?UTF-8?q?=E7=89=B9=E6=80=A7?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit 1.添加向Spring动态注册Bean的方法 --- .../cn/hutool/extra/spring/SpringUtil.java | 17 ++++++++++ .../hutool/extra/spring/SpringUtilTest.java | 32 ++++++++++++++++--- 2 files changed, 45 insertions(+), 4 deletions(-) diff --git a/hutool-extra/src/main/java/cn/hutool/extra/spring/SpringUtil.java b/hutool-extra/src/main/java/cn/hutool/extra/spring/SpringUtil.java index af0be5e8c..59cd3e3cd 100644 --- a/hutool-extra/src/main/java/cn/hutool/extra/spring/SpringUtil.java +++ b/hutool-extra/src/main/java/cn/hutool/extra/spring/SpringUtil.java @@ -4,6 +4,7 @@ import cn.hutool.core.lang.TypeReference; import cn.hutool.core.util.ArrayUtil; import org.springframework.context.ApplicationContext; import org.springframework.context.ApplicationContextAware; +import org.springframework.context.ConfigurableApplicationContext; import org.springframework.core.ResolvableType; import org.springframework.stereotype.Component; @@ -148,6 +149,22 @@ public class SpringUtil implements ApplicationContextAware { final String[] activeProfiles = getActiveProfiles(); return ArrayUtil.isNotEmpty(activeProfiles) ? activeProfiles[0] : null; } + + /** + * 动态向Spring注册Bean + *

+ * 由{@link org.springframework.beans.factory.BeanFactory} 实现,通过工具开放API + * + * @param beanName 名称 + * @param bean bean + * @param 泛型 + * @author shadow + * @date 2020-09-04 + */ + public static void registerBean(String beanName, T bean) { + ConfigurableApplicationContext context = (ConfigurableApplicationContext) applicationContext; + context.getBeanFactory().registerSingleton(beanName, bean); + } } diff --git a/hutool-extra/src/test/java/cn/hutool/extra/spring/SpringUtilTest.java b/hutool-extra/src/test/java/cn/hutool/extra/spring/SpringUtilTest.java index e7fbaed87..50553751c 100644 --- a/hutool-extra/src/test/java/cn/hutool/extra/spring/SpringUtilTest.java +++ b/hutool-extra/src/test/java/cn/hutool/extra/spring/SpringUtilTest.java @@ -10,6 +10,7 @@ import org.springframework.boot.test.context.SpringBootTest; import org.springframework.context.annotation.Bean; import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; +import javax.swing.*; import java.util.HashMap; import java.util.Map; @@ -18,11 +19,34 @@ import java.util.Map; //@Import(cn.hutool.extra.spring.SpringUtil.class) public class SpringUtilTest { + /** + * 注册bean + * + * 为了保证顺序采用顺序abcdef...形式命名方法 + */ + @Test + public void a() { + Demo2 registerBean = new Demo2(); + registerBean.id = 123; + registerBean.name = "222"; + SpringUtil.registerBean("registerBean", registerBean); + } + + /** + * 验证注册的bean + */ + @Test + public void b() { + Demo2 registerBean = SpringUtil.getBean("registerBean"); + Assert.assertEquals(123, registerBean.id); + Assert.assertEquals("222", registerBean.name); + } + @Test public void getBeanTest(){ final Demo2 testDemo = SpringUtil.getBean("testDemo"); - Assert.assertEquals(12345, testDemo.getId()); - Assert.assertEquals("test", testDemo.getName()); + Assert.assertEquals(12345, testDemo.id); + Assert.assertEquals("test", testDemo.name); } @Test @@ -41,8 +65,8 @@ public class SpringUtilTest { @Bean(name="testDemo") public Demo2 generateDemo() { Demo2 demo = new Demo2(); - demo.setId(12345); - demo.setName("test"); + demo.id = 12345; + demo.name= "test"; return demo; }