您好,登錄后才能下訂單哦!
前言
JavaConfig 原來是 Spring 的一個子項目,它通過 Java 類的方式提供 Bean 的定義信息,在 Spring4 的版本, JavaConfig 已正式成為 Spring4 的核心功能 。
本文將詳細介紹關于Spring中基于Java類進行配置的相關內容,下面話不多說了,來一起看看詳細的介紹吧
1 定義 Bean
普通的 POJO 只要標注了 @Configuration 注解,就可以為 Spring 容器提供 Bean 的定義信息。
@Configuration public class SystemConfig { /** * 定義 Bean,并實例化 * * @return */ @Bean public UserDao userDao() { return new UserDao(); } @Bean public DeptDao deptDao() { return new DeptDao(); } /** * 定義 UserService,并把之前定義的 UserDao 與 DeptDao 注入進來 * * @return */ @Bean public UserService userService() { UserService service = new UserService(); service.setUserDao(userDao()); service.setDeptDao(deptDao()); return service; } }
這個類的方法標注了 @Bean 注解,即為定義 Bean, Bean 的類型由方法返回值的類型決定,名稱默認和方法名同名,也可以通過入參顯示指定 Bean 名稱,比如 @Bean(name=”xxx”)。 @Bean 所標注的方法體提供了 實例化 Bean 的邏輯 。
以上配置和下面的 xml 是等效的:
<bean id="userDao" class="net.deniro.spring4.conf.UserDao"/> <bean id="deptDao" class="net.deniro.spring4.conf.DeptDao"/> <bean id="userService" class="net.deniro.spring4.conf.UserService" p:userDao-ref="userDao" p:deptDao-ref="deptDao"/>
基于 Java 類的配置方式和基于 XML 或者基于注解的配置方式相比——
因為 @Configuration 注解類本身已經標注了 @Component,所以這些類可以像那些普通的 Bean 一樣被注入到其他的 Bean 中。
@Configuration public class ApplicationConfig { @Autowired private SystemConfig systemConfig; @Bean public AuthorityService authorityService() { AuthorityService service = new AuthorityService(); service.setUserDao(systemConfig.userDao()); service.setDeptDao(systemConfig.deptDao()); return service; } }
Spring 會對配置類中所有標注了 @Bean 的方法使用 AOP 增強,引入 Bean 的生命周期管理邏輯。比如上面的 systemConfig.userDao(),它返回的是對應 Bean 的單例。
在 @Bean 中,我們還可以通過標注 @Scope 注解來控制 Bean 的作用范圍:
@Scope("prototype") @Bean public DeptDao deptDao() { return new DeptDao(); }
這樣每次調用 deptDao() 方法都會返回一個新的實例:
assertNotSame(authorityService.getDeptDao().hashCode(),authorityService .getDeptDao().hashCode());
注意: 使用基于 Java 類進行配置,類路徑下必須有 Spring AOP 與 CGLib 庫。
2 啟動 Spring 容器
2.1 只使用 @Configuration 類
可以使用 AnnotationConfigApplicationContext 類的構造函數傳入標注了 @Configuration 的 Java 類來啟動 Spring 容器 。
ApplicationContext context=new AnnotationConfigApplicationContext(SystemConfig .class); UserService userService= (UserService) context.getBean("userService"); assertNotNull(userService);
如果存在多個 @Configuration 配置類,那么可以 AnnotationConfigApplicationContext 中注冊它們,然后再通過刷新容器應用這些配置類:
AnnotationConfigApplicationContext context=new AnnotationConfigApplicationContext(); //注冊多個配置類 context.register(SystemConfig.class); context.register(ApplicationConfig.class); //刷新容器(應用這些配置類) context.refresh(); ApplicationConfig config=context.getBean(ApplicationConfig.class); assertNotNull(config);
也可以通過 @Import 將多個配置類組裝到一個配置類中,然后僅需注冊這個組裝好的配置類 ,即可啟動容器:
@Configuration @Import(SystemConfig.class) public class ApplicationConfig2 { @Autowired private SystemConfig systemConfig; @Bean public AuthorityService authorityService() { AuthorityService service = new AuthorityService(); service.setUserDao(systemConfig.userDao()); service.setDeptDao(systemConfig.deptDao()); return service; } }
單元測試:
AnnotationConfigApplicationContext context=new AnnotationConfigApplicationContext(ApplicationConfig2.class); ApplicationConfig2 config=context.getBean(ApplicationConfig2.class); assertNotNull(config); final AuthorityService authorityService = config.authorityService(); assertNotNull(authorityService.getDeptDao()); assertNotSame(authorityService.getDeptDao().hashCode(),authorityService .getDeptDao().hashCode());
2.2 使用 XML 文件引用 @Configuration 類的配置
標注了 @Configuration 的配置類也是一個 Bean,所以它也可以被 Spring 的 <context:component-scan> 掃描到 。 因此如果希望將配置類組裝到 XML 的配置文件中,并通過 XML 的配置文件啟動 Spring,那么僅需要在 XML 中通過 <context:component-scan> 掃描到相應的配置類即可 。
<context:component-scan base-package="net.deniro.spring4.conf" resource-pattern="ApplicationConfig2.class" />
2.3 在 @Configuration 類中引用 XML 文件的配置
在 @Configuration 配置類中可以直接通過 @ImportResource 引入 XML 的配置文件,這樣就可以直接通過 @Autowired 引用 xml 配置文件中定義的 Bean。
配置文件:
<bean id="groupDao" class="net.deniro.spring4.conf.GroupDao"/> <bean id="roleDao" class="net.deniro.spring4.conf.RoleDao"/>
@Configuration 類:
@ImportResource("classpath:beans5-11.xml") @Configuration public class ServiceConfig { @Bean @Autowired public RelationService relationService(GroupDao groupDao,RoleDao roleDao){ RelationService service=new RelationService(); service.setGroupDao(groupDao); service.setRoleDao(roleDao); return service; } }
單元測試:
AnnotationConfigApplicationContext context=new AnnotationConfigApplicationContext (ServiceConfig.class); ServiceConfig config=context.getBean(ServiceConfig.class); assertNotNull(config); RelationService service=config.relationService((GroupDao) context.getBean ("groupDao"), (RoleDao) context .getBean ("roleDao")); assertNotNull(service.getRoleDao());
只要這些不同形式 Bean 的定義信息能夠加載到 Spring 容器中,那么 Spring 就可以智能的完成 Bean 之間的裝配 。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。