AccountController .java Java代碼 <!--[if gte vml 1]><v:shapetype id="_x0000_t75" coordsize="21600,21600" o:spt="75" o:preferrelative="t" path="m@4@5l@4@ ...
AccountController .java
Java代碼
1. /**
2. * 2010-1-23
3. */
4. package org.zlex.spring.controller;
5.
6. import javax.servlet.http.HttpServletRequest;
7. import javax.servlet.http.HttpServletResponse;
8.
9. import org.springframework.beans.factory.annotation.Autowired;
10. import org.springframework.stereotype.Controller;
11. import org.springframework.web.bind.ServletRequestUtils;
12. import org.springframework.web.bind.annotation.RequestMapping;
13. import org.springframework.web.bind.annotation.RequestMethod;
14. import org.zlex.spring.service.AccountService;
15.
16. /**
17. *
18. * @author <a href="mailto:[email protected]">梁棟</a>
19. * @version 1.0
20. * @since 1.0
21. */
22. @Controller
23. @RequestMapping("/account.do")
24. public class AccountController {
25.
26. @Autowired
27. private AccountService accountService;
28.
29. @RequestMapping(method = RequestMethod.GET)
30. public void hello(HttpServletRequest request, HttpServletResponse response)
31. throws Exception {
32.
33. String username = ServletRequestUtils.getRequiredStringParameter(
34. request, "username");
35. String password = ServletRequestUtils.getRequiredStringParameter(
36. request, "password");
37. System.out.println(accountService.verify(username, password));
38. }
39. }
分段詳述:
Java代碼
1. @Controller
2. @RequestMapping("/account.do")
這兩行註解,@Controller是告訴Spring容器,這是一個控制器類,@RequestMapping("/account.do")是來定義該控制器對應的請求路徑(/account.do)
Java代碼
1. @Autowired
2. private AccountService accountService;
這是用來自動織入業務層實現AccountService,有了這個註解,我們就可以不用寫setAccountService()方法了!
同時,JSR-250標準註解,推薦使用@Resource來代替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裝配順序
1. 如果同時指定了name和type,則從Spring上下文中找到唯一匹配的bean進行裝配,找不到則拋出異常
2. 如果指定了name,則從上下文中查找名稱(id)匹配的bean進行裝配,找不到則拋出異常
3. 如果指定了type,則從上下文中找到類型匹配的唯一bean進行裝配,找不到或者找到多個,都會拋出異常
4. 如果既沒有指定name,又沒有指定type,則自動按照byName方式進行裝配(見2);如果沒有匹配,則回退為一個原始類型(UserDao)進行匹配,如果匹配則自動裝配;
1.6. @PostConstruct(JSR-250)
在方法上加上註解@PostConstruct,這個方法就會在Bean初始化之後被Spring容器執行(註:Bean初始化包括,實例化Bean,並裝配Bean的屬性(依賴註入))。
Java代碼
1.@RequestMapping(method = RequestMethod.GET)
2.public void hello(HttpServletRequest request, HttpServletResponse response)
3. throws Exception {
4.
5. String username = ServletRequestUtils.getRequiredStringParameter(
6. request, "username");
7. String password = ServletRequestUtils.getRequiredStringParameter(
8. request, "password");
9. System.out.println(accountService.verify(username, password));
10. }
註解@RequestMapping(method
= RequestMethod.GET)指定了訪問方法類型。
註意,如果沒有用這個註解標識方法,Spring容器將不知道那個方法可以用於處理get請求!
對於方法名,我們可以隨意定!方法中的參數,類似於“HttpServletRequest request, HttpServletResponse response”,只要你需要方法可以是有參也可以是無參
介面不需要任何Spring註解相關的東西,它就是一個簡單的介面!
重要的部分在於實現層,如下所示:
AccountServiceImpl.java
Java代碼
1./**
2. * 2010-1-23
3. */
4.package org.zlex.spring.service.impl;
5.