1. 程式人生 > 實用技巧 >Linux防火牆

Linux防火牆

轉自:https://www.jb51.net/article/184822.htm

Spring @Configuration註解

Spring3.0開始,@Configuration用於定義配置類,定義的配置類可以替換xml檔案,一般和@Bean註解聯合使用。

@Configuration註解主要標註在某個類上,相當於xml配置檔案中的<beans>

@Bean註解主要標註在某個方法上,相當於xml配置檔案中的<bean>

等價於

注意:@Configuration註解的配置類有如下要求:

  • @Configuration不可以是final型別;
  • @Configuration不可以是匿名類;
  • 巢狀的configuration必須是靜態類。

Configuration裡面有一個component元件來標識,說明此類也是一個bean,可以被呼叫,來看看哪些主要的註解含有component:

Annotation 的裝配 Spring 中,儘管使用 XML 配置檔案可以實現 Bean 的裝配工作,但如果應用中有很多 Bean 時,會導致 XML 配置檔案過於靡腫,給後續的維護和升級工作帶來一定的困難 為此, Spring 提供了對 Annotation (註解)技術的全面支援 Spring 中定義了一系列的註解,常用的註解如下所示

  • • @Component: 可以使用此註解描述 Spring 中的 Bean ,但它是一個泛化的概念,僅僅表 示一個元件 (Bean ,並且可以作用在任何層次 使用時只需將該註解標註在相應類上即可
  • • @Repository: 用於將資料訪問層( DAO 層)的類標識為 Spring 中的 Bean ,其功能與 @Component 相同
  • • @Service: 通常作用在業務層( Service ,用於將業務層的類標識為 Spring 中的 Bean 其功能與@Component 相同
  • • @Controller: 通常作用在控制層(如 Spring MVC Controller ,用於將控制層的類標識 Spring 中的 Bean ,其功能與@Component 相同
  • • @Autowired: 用於對 Bean 的屬性變數、屬性的 setter 方法及構造方法進行標註,配合對 應的註解處理器完成 Bean 的自動配置工作 預設按照 Bean 的型別進行裝配
  • • @Resource: 其作用與 Autowired 一樣 其區別在於@Autowired 預設按照 Bean 型別裝 配,而@Resource 預設按照 Bean 例項名稱進行裝配 @Resource 中有兩個重要屬性: name type Spring name 屬性解析為 Bean 例項名稱, type 屬性解析為 Bean 例項型別 如果 指定 name 屬性,貝IJ 按例項名稱進行裝配;如果指定 type 屬性,則按 Bean 型別進行裝配;如 果都不指定,則先按 Bean 例項名稱裝配,如果不能匹配,再按照 Bean 型別進行裝自己;如果都 無法匹配,則丟擲 NoSuchBeanDefinitionException 異常
  • • @Qualifier: @Autowired 註解配合使用,會將預設的按 Bean 型別裝配修改為接 Bean 的例項名稱裝配, Bean 的例項名稱由 @Qualifier 註解的引數指定 在上面幾個註解中,雖然@Repository @Service @Controller 功能與@Component 註解 的功能相同,但為了使標註類本身用途更加清晰,建議在實際開發中使用@Repository @Service @Controller 分別對實現類進行標註 下面。

@Configuration

這裡的@Configuration對我們來說不陌生,它就是JavaConfig形式的Spring Ioc容器的配置類使用的那個@Configuration,SpringBoot社群推薦使用基於JavaConfig的配置形式,所以,這裡的啟動類標註了@Configuration之後,本身其實也是一個IoC容器的配置類。

舉幾個簡單例子回顧下,XML跟config配置方式的區別:

表達形式層面

基於XML配置的方式是這樣:

1 2 3 4 5 6 7 <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd" default-lazy-init="true"> <!--bean定義--> </beans>

而基於JavaConfig的配置方式是這樣:

1 2 3 4 @Configuration public class MockConfiguration{ //bean定義 }

任何一個標註了@Configuration的Java類定義都是一個JavaConfig配置類。

註冊bean定義層面
基於XML的配置形式是這樣:

1 2 3 <bean id="mockService" class="..MockServiceImpl"> ... </bean>

而基於JavaConfig的配置形式是這樣的:

1 2 3 4 5 6 7 @Configuration public class MockConfiguration{ @Bean public MockService mockService(){ return new MockServiceImpl(); } }

任何一個標註了@Bean的方法,其返回值將作為一個bean定義註冊到Spring的IoC容器,方法名將預設成該bean定義的id。

表達依賴注入關係層面
為了表達bean與bean之間的依賴關係,在XML形式中一般是這樣:

1 2 3 4 5 <bean id="mockService" class="..MockServiceImpl"> <propery name ="dependencyService" ref="dependencyService" /> </bean> <bean id="dependencyService" class="DependencyServiceImpl"></bean>

而基於JavaConfig的配置形式是這樣的:

1 2 3 4 5 6 7 8 9 10 11 @Configuration public class MockConfiguration{ @Bean public MockService mockService(){ return new MockServiceImpl(dependencyService()); } @Bean public DependencyService dependencyService(){ return new DependencyServiceImpl(); } }

如果一個bean的定義依賴其他bean,則直接呼叫對應的JavaConfig類中依賴bean的建立方法就可以了。