1. 程式人生 > 其它 >@Service @Component、@Repository、@Service、@Controller區別

@Service @Component、@Repository、@Service、@Controller區別

service 是有用的相當於 xml配置中得bean id = service 也可以不指定 不指定相當於 bean id = com. service.service 就是這個類的全限定名,表示給當前類命名一個別名,方便注入到其他需要用到的類中;不加的話,預設別名就是當前類名,但是首字母小寫 。

@Service註解作用

1、 其getBean的預設名稱是類名(頭字母小寫),可以@Service(“xxxx”)這樣來指定, 2、其定義的bean預設是單例的,可以使用@Service(“beanName”) @Scope(“prototype”)來改變。
3、可以通過@PostConstruct和@PreDestroy指定初始化方法和銷燬方法(方法名任意)

@Service("baseCacheService")

public class BaseCacheServiceImpl implements BaseCacheService{

}
詳解
首先,在applicationContext.xml檔案中加一行:

<context:component-scan base-package="com.hzhi.clas"/>
加上這一行以後,將自動掃描路徑下面的包,如果一個類帶了@Service註解,將自動註冊到Spring容器,不需要再在applicationContext.xml檔案定義bean了,類似的還包括@Component、@Repository、@Controller。

比如下面這個類:

@Service("courseDAO")
@Scope("prototype")
public class CourseDAOImpl extends HibernateDaoSupport implements CourseDAO{

......

}
其作用就相當於applicationContext.xml檔案裡面的:

<bean id="courseDAO"
class="com.hzhi.course.dao.CourseDAOImpl" scope="prototype">
......
</bean>

Spring註解@Component、@Repository、@Service、@Controller區別

所以,如果 Web 應用程式採用了經典的三層分層結構的話,最好在持久層、業務層和控制層分別採用 @Repository、@Service 和 @Controller 對分層中的類進行註釋,而用 @Component 對那些比較中立的類進行註釋。

在一個稍大的專案中,通常會有上百個元件,如果這些元件採用xml的bean定義來配置,顯然會增加配置檔案的體積,查詢以及維護起來也不太方便。 Spring2.5為我們引入了元件自動掃描機制,他可以在類路徑底下尋找標註了@Component,@Service,@Controller,@Repository註解的類,並把這些類納入進spring容器中管理。它的作用和在xml檔案中使用bean節點配置元件時一樣的。要使用自動掃描機制,我們需要開啟以下配置資訊:
Java程式碼

<?xml version="1.0" encoding="UTF-8" ?> 
<beansxmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchemainstance"xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans 
http://www.springframework.org/schema/beans/spring-beans2.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為需要掃描的包(含所有子包) @Service用於標註業務層元件,@Controller用於標註控制層元件(如struts中的action),@Repository用於標註資料訪問元件,即DAO元件,而@Component泛指元件,當元件不好歸類的時候,我們可以使用這個註解進行標註。

@Service  
public class VentorServiceImpl implements iVentorService{     
}   
  
@Repository  
public class VentorDaoImpl implements iVentorDao {   
}   
  1. getBean的預設名稱是類名(頭字母小寫),如果想自定義,可以@Service(“aaaaa”)這樣來指定,這種bean預設是單例的,
  2. 如果想改變,可以使用
  3. @Service(“beanName”)
  4. @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註解的區別

BYETHANON2011年06月02日INJAVA

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註解進行使用,如下:

1

@Autowired()@Qualifier("baseDao")

2

privateBaseDao baseDao;

3、@Resource(這個註解屬於J2EE的),預設安裝名稱進行裝配,名稱可以通過name屬性進行指定,如果沒有指定name屬性,當註解寫在欄位上時,預設取欄位名進行安裝名稱查詢,如果註解寫在setter方法上預設取屬性名進行裝配。當找不到與名稱匹配的bean時才按照型別進行裝配。但是需要注意的是,如果name屬性一旦指定,就只會按照名稱進行裝配。

1

@Resource(name="baseDao")

2

privateBaseDao baseDao;

推薦使用:@Resource註解在欄位上,這樣就不用寫setter方法了,並且這個註解是屬於J2EE的,減少了與spring的耦合。這樣程式碼看起就比較優雅。