中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

在Spring中基于Java類進行配置的完整步驟

發布時間:2020-09-02 17:04:47 來源:腳本之家 閱讀:165 作者:deniro 欄目:編程語言

前言

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 或者基于注解的配置方式相比——

  • Java 類的配置方式通過代碼編程的方式,可以更加靈活地實例化 Bean 和裝配 Bean 之間的關系。
  • 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 之間的裝配 。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

宁武县| 辽中县| 建瓯市| 东兴市| 阿图什市| 靖边县| 大英县| 蒙自县| 周宁县| 顺平县| 吴川市| 嘉善县| 府谷县| 伊春市| 津市市| 任丘市| 宜春市| 东乡族自治县| 兴文县| 徐汇区| 东方市| 建阳市| 陇川县| 永济市| 唐河县| 惠东县| 平塘县| 鄂托克前旗| 塘沽区| 阜新| 民丰县| 永胜县| 贵德县| 南丹县| 龙山县| 获嘉县| 武宁县| 塔城市| 新邵县| 临清市| 巴楚县|