溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

在Spring中基于Java類進(jìn)行配置的完整步驟

發(fā)布時(shí)間:2020-09-02 17:04:47 來源:腳本之家 閱讀:158 作者:deniro 欄目:編程語言

前言

JavaConfig 原來是 Spring 的一個(gè)子項(xiàng)目,它通過 Java 類的方式提供 Bean 的定義信息,在 Spring4 的版本, JavaConfig 已正式成為 Spring4 的核心功能 。

本文將詳細(xì)介紹關(guān)于Spring中基于Java類進(jìn)行配置的相關(guān)內(nèi)容,下面話不多說了,來一起看看詳細(xì)的介紹吧

1 定義 Bean

普通的 POJO 只要標(biāo)注了 @Configuration 注解,就可以為 Spring 容器提供 Bean 的定義信息。

@Configuration
public class SystemConfig {
 /**
  * 定義 Bean,并實(shí)例化
  *
  * @return
  */
 @Bean
 public UserDao userDao() {
  return new UserDao();
 }

 @Bean
 public DeptDao deptDao() {
  return new DeptDao();
 }

 /**
  * 定義 UserService,并把之前定義的 UserDao 與 DeptDao 注入進(jìn)來
  *
  * @return
  */
 @Bean
 public UserService userService() {
  UserService service = new UserService();
  service.setUserDao(userDao());
  service.setDeptDao(deptDao());
  return service;
 }
}

這個(gè)類的方法標(biāo)注了 @Bean 注解,即為定義 Bean, Bean 的類型由方法返回值的類型決定,名稱默認(rèn)和方法名同名,也可以通過入?yún)@示指定 Bean 名稱,比如 @Bean(name=”xxx”)。 @Bean 所標(biāo)注的方法體提供了 實(shí)例化 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 或者基于注解的配置方式相比——

  • Java 類的配置方式通過代碼編程的方式,可以更加靈活地實(shí)例化 Bean 和裝配 Bean 之間的關(guān)系。
  • XML 或者基于注解的方式都是通過聲明來定義配置的,所以靈活性上要遜一些,但在配置上更簡單 。

因?yàn)?@Configuration 注解類本身已經(jīng)標(biāo)注了 @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 會(huì)對(duì)配置類中所有標(biāo)注了 @Bean 的方法使用 AOP 增強(qiáng),引入 Bean 的生命周期管理邏輯。比如上面的 systemConfig.userDao(),它返回的是對(duì)應(yīng) Bean 的單例。

在 @Bean 中,我們還可以通過標(biāo)注 @Scope 注解來控制 Bean 的作用范圍:

@Scope("prototype")
@Bean
public DeptDao deptDao() {
 return new DeptDao();
}

這樣每次調(diào)用 deptDao() 方法都會(huì)返回一個(gè)新的實(shí)例:

assertNotSame(authorityService.getDeptDao().hashCode(),authorityService
    .getDeptDao().hashCode());

注意: 使用基于 Java 類進(jìn)行配置,類路徑下必須有 Spring AOP 與 CGLib 庫。

2 啟動(dòng) Spring 容器

2.1 只使用 @Configuration 類

可以使用 AnnotationConfigApplicationContext 類的構(gòu)造函數(shù)傳入標(biāo)注了 @Configuration 的 Java 類來啟動(dòng) Spring 容器 。

ApplicationContext context=new AnnotationConfigApplicationContext(SystemConfig
  .class);
UserService userService= (UserService) context.getBean("userService");
assertNotNull(userService);

如果存在多個(gè) @Configuration 配置類,那么可以 AnnotationConfigApplicationContext 中注冊(cè)它們,然后再通過刷新容器應(yīng)用這些配置類:

AnnotationConfigApplicationContext context=new AnnotationConfigApplicationContext();

//注冊(cè)多個(gè)配置類
context.register(SystemConfig.class);
context.register(ApplicationConfig.class);

//刷新容器(應(yīng)用這些配置類)
context.refresh();

ApplicationConfig config=context.getBean(ApplicationConfig.class);
assertNotNull(config);

也可以通過 @Import 將多個(gè)配置類組裝到一個(gè)配置類中,然后僅需注冊(cè)這個(gè)組裝好的配置類 ,即可啟動(dòng)容器:

@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 類的配置

標(biāo)注了 @Configuration 的配置類也是一個(gè) Bean,所以它也可以被 Spring 的 <context:component-scan> 掃描到 。 因此如果希望將配置類組裝到 XML 的配置文件中,并通過 XML 的配置文件啟動(dòng) Spring,那么僅需要在 XML 中通過 <context:component-scan> 掃描到相應(yīng)的配置類即可 。

<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 之間的裝配 。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)億速云的支持。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI