Spring注解使用和與配置文件的關系
1 注解概述與容器管理機制
Spring 2.5 中除了提供 @Component 注釋外,還定義了幾個擁有特殊語義的注釋,它們分別是:@Repository、@Service 和 @Controller。在目前的 Spring 版本中,這 3 個注釋和 @Component 是等效的,但是從注解類的命名上,很容易看出這 3 個注解分別與持久層、業務層和控制層(Web 層)相對應。雖然目前這 3 個注釋和 @Component 相比沒有什么新意,但 Spring 將在以后的版本中為它們添加特殊的功能。所以,如果 Web 應用程序采用了經典的三層分層結構的話,最好在持久層、業務層和控制層分別采用 @Repository、@Service 和 @Controller 對分層中的類進行注釋,而用 @Component 對那些比較中立的類進行注釋。
在一個稍大的項目中,通常會有上百個組件,如果這些組件采用xml的bean定義來配置,顯然會增加配置文件的體積,查找以及維護起來也不太方便。 Spring2.5為我們引入了組件自動掃描機制,他可以在類路徑底下尋找標注了 @Component,@Service,@Controller,@Repository注解的類,並把這些類納入進spring容器中管理。它的作用和在xml文件中使用bean節點配置組件時一樣的。要使用自動掃描機制,我們需要打開以下配置信息:
<?xml version="1.0" encoding="UTF-8" ?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi=http://www.w3.org/2001/XMLSchema-instance
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-2.5.xsd" >
<context:component-scan base-package=”com.eric.spring”>
</beans>
其中base-package為需要掃描的包(含所有子包)
在 spring的配置文件里面只需要加上<context:annotation-config/> 和<context:component-scan base-package="需要實現注入的類所在包"/>,當然也可以使用base-package="*"表示全部的類,但一般情況下不這樣使用,影響系統性能,通常如下使用:
<context:component-scan base-package=”com.eric.spring”>
其中base-package為需要掃描的包(含所有子包)
2 注入方式:
把DAO實現類注入到service實現類中,把service的接口(注意不要是service的實現類)注入到action中,注入時不要new 這個注入的類,因為spring會自動注入,如果手動再new的話會出現錯誤,然后屬性加上@Autowired后不需要getter()和setter()方法,Spring也會自動注入。至於更具體的內容,等對注入的方式更加熟練后會做個完整的例子上來。
3 類注解說明
類注解就是在類定義上標注的注解,不是在類定義的里面加標注,是在類的前面標注。主要是4個注解:
@Service用於標注業務層組件,表示定義一個bean,自動根據bean的類名實例化一個首寫字母為小寫的bean,例如Chinese實例化為chinese,如果需要自己改名字則:@Service("你自己改的bean名")。
@Controller用於標注控制層組件(如struts中的action)
@Repository用於標注數據訪問的持久層組件,即DAO組件
@Component泛指組件,當組件不好歸類的時候,我們可以使用這個注解進行標注。
例如:
@Service
public class VentorServiceImpl implements iVentorService {
……
}
@Repository
public class VentorDaoImpl implements iVentorDao {
……
}
getBean的默認名稱是類名(頭字母小寫),如果想自定義,可以@Service(“aaaaa”)這樣來指定,這種bean默認是單例的,如果想改變,可以使用@Service(“beanName”) @Scope(“prototype”)來改變。
4 方法或變量注解說明
可以使用以下方式指定初始化方法和銷毀方法(方法名任意):
@PostConstruct
public void init() {
……
}
@PreDestroy
public void destory() {
……
}
在接口前面標上@Autowired和@Qualifier注解使得接口可以被容器注入,當接口存在兩個實現類的時候必須指定其中一個來注入,使用實現類首字母小寫的字符串來注入,如:
@Autowired
@Qualifier("chinese")
private Man man;
否則可以省略,只寫@Autowired 。
