service 是有用的相當於 xml配置中得bean id = service 也可以不指定 不指定相當於 bean id = com. service.service 就是這個類的全限定名,表示給當前類命名一個別名,方便注入到其他需要用到的類中;不加的話,默認別名就是當前類名,但是首字母小寫
Spring注解@Component、@Repository、@Service、@Controller區別
所以,如果 Web 應用程序采用了經典的三層分層結構的話,最好在持久層、業務層和控制層分別采用 @Repository、@Service 和 @Controller 對分層中的類進行注釋,而用 @Component 對那些比較中立的類進行注釋。
在一個稍大的項目中,通常會有上百個組件,如果這些組件采用xml的bean定義來配置,顯然會增加配置文件的體積,查找以及維護起來也不太方便。 Spring2.5為我們引入了組件自動掃描機制,他可以在類路徑底下尋找標注了@Component,@Service,@Controller,@Repository注解的類,並把這些類納入進spring容器中管理。它的作用和在xml文件中使用bean節點配置組件時一樣的。要使用自動掃描機制,我們需要打開以下配置信息:
Java代碼
1. <?xml version="1.0" encoding="UTF-8" ?> <beansxmlns="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"
2. >
3.
4. <context:component-scan base-package=”com.eric.spring”>
5. </beans>
6. 其中base-package為需要掃描的包(含所有子包) @Service用於標注業務層組件,@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”)來改變。可以使用以下方式指定初始化方法和銷毀方法(方法名任意):
- @PostConstruct
- public void init() {
- }
- @PreDestroy
- public void destory() {
- }
注入方式:
把DAO實現類注入到service實現類中,把service的接口(注意不要是service的實現類)注入到action中,注
入時不要new 這個注入的類,因為spring會自動注入,如果手動再new的話會出現錯誤,然后屬性加上
@Autowired后不需要getter()和setter()方法,Spring也會自動注入。至於更具體的內容,等對注入的方式更
加熟練后會做個完整的例子上來。
注解:
在 spring的配置文件里面只需要加上<context:annotation-config/>和<context:component-scanbase-package="需要實現注入的類所在包"/>,
可以使用base-package="*"表示全部的類。
< context:component-scan base-package=”com.eric.spring”>
其中base-package為需要掃描的包(含所有子包)
在接口前面標上@Autowired和@Qualifier注釋使得接口可以被容器注入,當接口存在兩個實現類的時候必須指定其中一個來注入,
使用實現類首字母小寫的字符串來注入,如:
@Autowired
@Qualifier("chinese")
private Man man;
否則可以省略,只寫@Autowired 。
@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”)來改變。
可以使用以下方式指定初始化方法和銷毀方法(方法名任意):
@PostConstruct
public void init() {
}
@PreDestroy
public void destory() {
}
Spring中@Autowired注解、@Resource注解的區別
BY ETHAN ON 2011年 06 月 02 日 IN JAVA
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裝配順序
1. 如果同時指定了name和type,則從Spring上下文中找到唯一匹配的bean進行裝配,找不到則拋出異常
2. 如果指定了name,則從上下文中查找名稱(id)匹配的bean進行裝配,找不到則拋出異常
3. 如果指定了type,則從上下文中找到類型匹配的唯一bean進行裝配,找不到或者找到多個,都會拋出異常
4. 如果既沒有指定name,又沒有指定type,則自動按照byName方式進行裝配;如果沒有匹配,則回退為一個原始類型進行匹配,如果匹配則自動裝配;
@Autowired 與@Resource的區別:
1、 @Autowired與@Resource都可以用來裝配bean.都可以寫在字段上,或寫在setter方法上。
2、 @Autowired默認按類型裝配(這個注解是屬業spring的),默認情況下必須要求依賴對象必須存在,如果要允許null值,可以設置它的required屬性為false,如:@Autowired(required=false),如果我們想使用名稱裝配可以結合@Qualifier注解進行使用,如下:
|
|
|
|
3、@Resource(這個注解屬於J2EE的),默認安裝名稱進行裝配,名稱可以通過name屬性進行指定,如果沒有指定name屬性,當注解寫在字段上時,默認取字段名進行安裝名稱查找,如果注解寫在setter方法上默認取屬性名進行裝配。當找不到與名稱匹配的bean時才按照類型進行裝配。但是需要注意的是,如果name屬性一旦指定,就只會按照名稱進行裝配。
|
|
|
|
|
推薦使用:@Resource注解在字段上,這樣就不用寫setter方法了,並且這個注解是屬於J2EE的,減少了與spring的耦合。這樣代碼看起就比較優雅。