1. 程式人生 > >Spring 註解總結

Spring 註解總結

宣告:這是轉載的。
內容根據網上資料整理。

相關連結:
http://www.360doc.com/content/10/1118/16/2371584_70449913.shtml
http://www.iteye.com/topic/1121784

http://www.iteye.com/topic/295348

【正文】

一 註解優點?註解解決了什麼問題,為什麼要使用註解?

二 註解的來龍去脈(歷史)

Spring 3.1 Reference 對註解與XML對比的一段敘述:

1 沒有註解之前

  1. publicclass UserManagerImpl implements
     UserManager {    
  2.     private UserDao userDao;    
  3.     publicvoid setUserDao(UserDao userDao) {    
  4.         this.userDao = userDao;    
  5.     }    
  6.     ...    
  7. }    

配置檔案
  1. <beanid="userManagerImpl"class="com.kedacom.spring.annotation.service.UserManagerImpl">
  2.     <property
    name="userDao"ref="userDao"/>
  3. </bean>
  4. <beanid="userDao"class="com.kedacom.spring.annotation.persistence.UserDaoImpl">
  5.     <propertyname="sessionFactory"ref="mySessionFactory"/>
  6. </bean>


2 註解誕生之後

  1. publicclass UserManagerImpl implements UserManager {    
  2.     @Autowired
  3.     private UserDao userDao;    
  4.     ...    
  5. }   

或者(對方法進行標註)
  1. publicclass UserManagerImpl implements UserManager {    
  2.     private UserDao userDao;    
  3.     @Autowired
  4.     publicvoid setUserDao(UserDao userDao) {    
  5.         this.userDao = userDao;    
  6.     }    
  7.     ...    
  8. }   

配置檔案
  1. <beanid="userManagerImpl"class="com.kedacom.spring.annotation.service.UserManagerImpl"/>
  2. <beanid="userDao"class="com.kedacom.spring.annotation.persistence.UserDaoImpl">
  3.     <propertyname="sessionFactory"ref="mySessionFactory"/>
  4. </bean>

@Autowired可以對成員變數、方法和建構函式進行標註,來完成自動裝配的工作。以上兩種不同實現方式中,@Autowired的標註位置不同,它們都會在Spring在初始化userManagerImpl這個bean時,自動裝配userDao這個屬性,區別是:第一種實現中,Spring會直接將UserDao型別的唯一一個bean賦值給userDao這個成員變數;第二種實現中,Spring會呼叫setUserDao方法來將UserDao型別的唯一一個bean裝配到userDao這個屬性。

要使@Autowired能夠工作,還需要在配置檔案中加入以下程式碼 

  1. <beanclass="org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor"/>

可以看到確實是減少了程式碼和配置檔案中的配置。


三 註解總體介紹

註解實現Bean配置主要用來進行如依賴注入、生命週期回撥方法定義等,不能消除XML檔案中的Bean元資料定義,且基於XML配置中的依賴注入的資料將覆蓋基於註解配置中的依賴注入的資料。
Spring3的基於註解實現Bean依賴注入支援如下三種註解:
Spring自帶依賴注入註解: Spring自帶的一套依賴注入註解;
JSR-250註解:Java平臺的公共註解,是Java EE 5規範之一,在JDK6中預設包含這些註解,從Spring2.5開始支援。
JSR-330註解:Java 依賴注入標準,Java EE 6規範之一,可能在加入到未來JDK版本,從Spring3開始支援;
JPA註解:用於注入持久化上下文和屍體管理器。
這三種類型的註解在Spring3中都支援,類似於註解事務支援,想要使用這些註解需要在Spring容器中開啟註解驅動支援,即使用如下配置方式開啟:
  1. <beansxmlns="http://www.springframework.org/schema/beans"
  2.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  3.     xmlns:context="http://www.springframework.org/schema/context"
  4.     xsi:schemaLocation=" http://www.springframework.org/schema/beans    
  5.        http://www.springframework.org/schema/beans/spring-beans-3.0.xsd    
  6.        http://www.springframework.org/schema/context    
  7.        http://www.springframework.org/schema/context/spring-context-3.0.xsd">
  8.     <context:annotation-config/>
  9. </beans>




這樣就能使用註解驅動依賴注入了
Spring自帶依賴注入註解

1 @Required:依賴檢查;
2 @Autowired:自動裝配2 
自動裝配,用於替代基於XML配置的自動裝配
基於@Autowired的自動裝配,預設是根據型別注入,可以用於構造器、欄位、方法注入
3 @Value:注入SpEL表示式
用於注入SpEL表示式,可以放置在欄位方法或引數上
@Value(value = "SpEL表示式")  
@Value(value = "#{message}")  
4 @Qualifier:限定描述符,用於細粒度選擇候選者
@Qualifier限定描述符除了能根據名字進行注入,但能進行更細粒度的控制如何選擇候選者
@Qualifier(value = "限定識別符號") 


JSR-250註解

1 @Resource:自動裝配,預設根據型別裝配,如果指定name屬性將根據名字裝配,可以使用如下方式來指定
@Resource(name = "識別符號")  
欄位或setter方法 

2 @PostConstruct和PreDestroy:通過註解指定初始化和銷燬方法定義

JSR-330註解
1 @Inject:等價於預設的@Autowired,只是沒有required屬性
2 @Named:指定Bean名字,對應於Spring自帶@Qualifier中的預設的根據Bean名字注入情況
3 @Qualifier:只對應於Spring自帶@Qualifier中的擴充套件@Qualifier限定描述符註解,即只能擴充套件使用,沒有value屬性


JPA註解
@PersistenceContext
@PersistenceUnit

用於注入EntityManagerFactory和EntityManager

四 註解需要的jar包及配置


五 拓展:結合區域性程式碼來說明註解

1 @Autowired 同二 註解歷史中的內容,此處不重複。 2 @Qualifier @Autowired是根據型別進行自動裝配的。在上面的例子中,如果當Spring上下文中存在不止一個UserDao型別的bean時,就會丟擲BeanCreationException異常;如果Spring上下文中不存在UserDao型別的bean,也會丟擲BeanCreationException異常。我們可以使用@Qualifier配合@Autowired來解決這些問題。
1>可能存在多個UserDao例項 
  1. @Autowired
  2. publicvoid setUserDao(@Qualifier("userDao") UserDao userDao) {    
  3.     this.userDao = userDao;    
  4. }    

這樣,Spring會找到id為userDao的bean進行裝配。 
2>可能不存在UserDao例項 
  1. @Autowired(required = false)    
  2. publicvoid setUserDao(UserDao userDao) {    
  3.     this.userDao = userDao;    
  4. }    

3 @Resource(JSR-250標準註解,推薦使用它來代替Spring專有的@Autowired註解) 
Spring 不但支援自己定義的@Autowired註解,還支援幾個由JSR-250規範定義的註解,它們分別是@Resource、@PostConstruct以及@PreDestroy。 
@Resource的作用相當於@Autowired,只不過@Autowired按byType自動注入,而@Resource預設按byName自動注入罷了。@Resource有兩個屬性是比較重要的,分別是name和type,Spring將@Resource註解的name屬性解析為bean的名字,而type屬性則解析為bean的型別。所以如果使用name屬性,則使用byName的自動注入策略,而使用type屬性時則使用byType自動注入策略。如果既不指定name也不指定type屬性,這時將通過反射機制使用byName自動注入策略。 
@Resource裝配順序 
如果同時指定了name和type,則從Spring上下文中找到唯一匹配的bean進行裝配,找不到則丟擲異常
如果指定了name,則從上下文中查詢名稱(id)匹配的bean進行裝配,找不到則丟擲異常
如果指定了type,則從上下文中找到型別匹配的唯一bean進行裝配,找不到或者找到多個,都會丟擲異常
如果既沒有指定name,又沒有指定type,則自動按照byName方式進行裝配(見2);如果沒有匹配,則回退為一個原始型別(UserDao)進行匹配,如果匹配則自動裝配; 4 @PostConstruct(JSR-250) 
在方法上加上註解@PostConstruct,這個方法就會在Bean初始化之後被Spring容器執行(注:Bean初始化包括,例項化Bean,並裝配Bean的屬性(依賴注入))。 
它的一個典型的應用場景是,當你需要往Bean裡注入一個其父類中定義的屬性,而你又無法複寫父類的屬性或屬性的setter方法時,如: 
  1. publicclass UserDaoImpl extends HibernateDaoSupport implements UserDao {    
  2.     private SessionFactory mySessionFacotry;    
  3.     @Resource
  4.     publicvoid setMySessionFacotry(SessionFactory sessionFacotry) {    
  5.         this.mySessionFacotry = sessionFacotry;    
  6.     }    
  7.     @PostConstruct
  8.     publicvoid injectSessionFactory() {    
  9.         super.setSessionFactory(mySessionFacotry);    
  10.     }    
  11.     ...    
  12. }    

這裡通過@PostConstruct,為UserDaoImpl的父類裡定義的一個sessionFactory私有屬性,注入了我們自己定義的sessionFactory(父類的setSessionFactory方法為final,不可複寫),之後我們就可以通過呼叫super.getSessionFactory()來訪問該屬性了。
5 @PreDestroy(JSR-250) 
在方法上加上註解@PreDestroy,這個方法就會在Bean初始化之後被Spring容器執行。由於我們當前還沒有需要用到它的場景,這裡不不去演示。其用法同@PostConstruct。 6 使用<context:annotation-config />簡化配置 
Spring2.1添加了一個新的context的Schema名稱空間,該名稱空間對註釋驅動、屬性檔案引入、載入期織入等功能提供了便捷的配置。我們知道註釋本身是不會做任何事情的,它僅提供元資料資訊。要使元資料資訊真正起作用,必須讓負責處理這些元資料的處理器工作起來。  AutowiredAnnotationBeanPostProcessor和CommonAnnotationBeanPostProcessor就是處理這些註釋元資料的處理器。但是直接在Spring配置檔案中定義這些Bean顯得比較笨拙。Spring為我們提供了一種方便的註冊這些BeanPostProcessor的方式,這就是<context:annotation-config />:
  1. <beansxmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns:context="http://www.springframework.org/schema/context"
  2.     xsi:schemaLocation="http://www.springframework.org/schema/beans    
  3.     http://www.springframework.org/schema/beans/spring-beans-2.5.xsd    
  4.     http://www.springframework.org/schema/context    
  5.     http://www.springframework.org/schema/context/spring-context-2.5.xsd">
  6.     <context:annotation-config/>
  7. </beans>

<context:annotationconfig />將隱式地向Spring容器註冊AutowiredAnnotationBeanPostProcessor、CommonAnnotationBeanPostProcessor、 PersistenceAnnotationBeanPostProcessor以及RequiredAnnotationBeanPostProcessor這4個BeanPostProcessor。
使用Spring註解完成Bean的定義 
以上我們介紹了通過@Autowired或@Resource來實現在Bean中自動注入的功能,下面我們將介紹如何註解Bean,從而從XML配置檔案中完全移除Bean定義的配置。
7 @Component(不推薦使用)、@Repository、@Service、@Controller 
只需要在對應的類上加上一個@Component註解,就將該類定義為一個Bean了:
  1. @Component
  2. public

    相關推薦

    java spring註解總結

    註解是個好東西,但好東西我們也是看見過,整理過,理解過,用過才知道好。不求我們每個都記住,但求保有印象,在需要的時候能提取出來再查詢相關資料,平時工作就不會顯得那麼被動了。[email protected]註解該類等價 與XML中配置beans,相當於Ioc容器,它

    spring註解總結

    1、@RestController @RestController註解,相當於@[email protected]兩個註解的結合,類中的所有方法都自動加上@ResponseBody註解,因此不能返回jsp,html頁面,檢視解析器無法解析jsp,html頁面。

    Spring 註解總結

    宣告:這是轉載的。 內容根據網上資料整理。 相關連結: http://www.360doc.com/content/10/1118/16/2371584_70449913.shtml http://www.iteye.com/topic/1121784 http://www.iteye.com/

    spring學習筆記四:spring常用註解總結

    bean logs single 配置文件 屬性註入 ring 如果 let ons 使用spring的註解,需要在配置文件中配置組件掃描器,用於在指定的包中掃描註解 <context:component-scan base-package="xxx.xxx.xxx

    Spring Boot常用註解總結

    auto 基於 back rgs enable glob 裝配 內容 註意 Spring Boot常用註解總結 @RestController和@RequestMapping註解 @RestController註解,它繼承自@Controller註解。4.0之前的版本,Sp

    Spring常用註解總結

    doc exc ise bject factor 功能 一個 ets -s 傳統的Spring做法是使用.xml文件來對bean進行註入或者是配置aop、事物,這麽做有兩個缺點:1、如果所有的內容都配置在.xml文件中,那麽.xml文件將會十分龐大;如果按需求分開.xml文

    spring和springboot常用註解總結

    普通 map 組件 構造 sca service 提交 依賴 demo1 @RequestMapping 這個註解可以用於類和方法上,用於類上,表示父路徑,如類上是demo,方法上是/demo1,那麽訪問路徑就是demo/demo1 該註解有六個屬性:params:指定re

    Spring知識點總結(三)之註解方式實現IOC和DI

        1. 註解概念        所謂註解就是給程式看的提示資訊,很多時候都用來作為輕量級配置的方式。        關於註解的知識點,參看java基礎課程

    atititt java定時任務框架選型Spring Quartz 註解總結

    分享一下我老師大神的人工智慧教程!零基礎,通俗易懂!http://blog.csdn.net/jiangjunshow 也歡迎大家轉載本篇文章。分享知識,造福人民,實現我們中華民族偉大復興!        

    Spring常見註解總結 總結

    接觸了公司的專案程式碼後發現,現在基本上用SSM框架的都是全註解注入開發,之前自學SSM時做的小專案都是XML配置注入。maven都用了,還不用註解?開發效率太低嘍。 關於註解開發的好處可以參考介個連結。https://blog.csdn.net/wxw520zdh/article/detail

    Spring學習總結(27)——Spring常用註解總結

    1、宣告Bean的註解 @Component  元件,沒有明確的角色。 @Service  在業務邏輯層使用(service層)。 @Repository  在資料訪問層使用(dao層)。 @Controller  在展現層使用,控制器的宣告(Controller層)

    Spring -13 -Spring 中常用註解總結

    [email protected] 建立類物件,相當於配置<bean/> [email protected] 與@Component 功能相同.   2.1都寫在ServiceImpl 類上. [email protected] 與@Component 功

    Spring Boot(5)---常用註解總結

    Spring Boot常用註解總結 @RestController和@RequestMapping註解 @RestController註解,它繼承自@Controller註解。4.0之前的版本,Spring MVC的元件都使用@Controller來標識當前類是一個控制器

    java面試總結(七)—— Spring註解

    @Controller 用於標記在一個類上,宣告註解的類是一個Controller,將該類交給Spring容器進行管理,可以使Controller定義更加靈活,可以不用實現Controller介面,請求處理的方法也更加靈活。 分發處理器將會掃描使用了該註解的

    spring cloud與docker微服務架構實戰》註解總結

    基於spring-boot 1.4.3.RELEASE 和 spring-cloud Camden.SR4 的註解總結一、spring-cloud註解1、@SpringBootApplication spring啟動註解2、@EnableEurekaServer 註冊為Eur

    spring booot日常學習註解總結

    [email protected] : 應用位置:第一,應用在方法上                   第二,應用在方法的引數上        

    Spring各類註解總結

    @Component 泛指各種元件,就是說當我們的類不屬於各種歸類的時候(不屬於@Controller、@Services等的時候),我們就可以使用@Component來標註這個類。@controller 控制器(注入服務)用於標註控制層,相當於struts中的action層

    ActiveMQ學習總結(10)——ActiveMQ採用Spring註解方式傳送和監聽

    對於ActiveMQ訊息的傳送,原聲的api操作繁瑣,而且如果不進行二次封裝,開啟關閉會話以及各種建立操作也是夠夠的了。那麼,Spring提供了一個很方便的去收發訊息的框架,spring jms。整

    Spring Boot的條件註解總結

    Spring Boot的條件註解位於org.springframework.boot.autoconfigure.condition包下,其對應的處理類在它上面的Conditional註解裡宣告。 Spring Boot的條件註解 註解

    基於Spring註解的資料庫獲取不同DataSource的總結

    /** * */ package com.soundsystem.config; import javax.sql.DataSource; import org.apache.commons.dbcp.BasicDataSource; import o