@Component
@Repository
@Service
@Controller
目前這些沒有啥太大的差別 都是在實作類上進行标注 說明這是一個元件。
從名字上可以看出:
@Service用于标注業務層元件,
@Controller用于标注控制層元件(如struts中的action),
@Repository用于标注資料通路元件,即DAO元件,
@Component泛指元件,當元件不好歸類的時候,我們可以使用這個注解進行标注。
@Autowired 可以對成員變量、方法和構造函數進行标注,來完成自動裝配的工作。@Autowired的标注位置不同,它們都會在Spring 在初始化userManagerImpl這個bean時,自動裝配userDao這個屬性,差別是:第一種實作中,Spring會直接将UserDao類型的唯一一個bean指派給userDao這個成員變量;第二種實作中,Spring會調用setUserDao方法來将UserDao類型的唯一一個 bean裝配到userDao這個屬性。
@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)進行比對,如果比對則自動裝配
- 過濾器類型 表達式範例 說明
- 注解 org.example.SomeAnnotation 将所有使用SomeAnnotation注解的類過濾出來
- 類名指定 org.example.SomeClass 過濾指定的類
- 正規表達式 com\.kedacom\.spring\.annotation\.web\..* 通過正規表達式過濾一些類
- AspectJ表達式 org.example..*Service+ 通過AspectJ表達式過濾一些類
- @Scope("session")
- @Component()
- public class UserSessionBean implements Serializable {
- ...
- }