springMVC3學習(十)--註解式控制器
Spring2.5引入註解式處理器支援,通過@Controller和@RequestMapping註解定義
我們的處理器類。並且提供了一組強大的註解
需要通過處理器對映DefaultAnnotationHandlerMapping和處理器介面卡AnnotationMethodHandlerAdapter
來開啟支援@Controller和@RequestMapping註解的處理器。@Controller:用於標識是處理器類;
@RequestMapping:請求到處理器功能方法的對映規則;
@RequestParam:請求引數到處理器功能處理方法的方法引數上的繫結;
@ModelAttribute:請求引數到命令物件的繫結;
@InitBinder:自定義資料繫結註冊支援,用於將請求引數轉換到命令物件屬性的對應型別;一、簡單例子
1、控制器實現
[java] view plain copy
- import javax.servlet.http.HttpServletRequest;
- import javax.servlet.http.HttpServletResponse;
- import org.springframework.stereotype.Controller;
- import org.springframework.web.bind.annotation.RequestMapping;
- import org.springframework.web.servlet.ModelAndView;
- @Controller
- public class Login{
- @RequestMapping(value="/login.do") //②請求URL到處理器功能處理方法的對映
- public ModelAndView hello(HttpServletRequest request,HttpServletResponse response){
- ModelAndView mv = new ModelAndView();
- mv.addObject("message", "Hello World!");
- //設定邏輯檢視名,檢視解析器會根據該名字解析到具體的檢視頁面
- mv.setViewName("login");
- return mv; //③模型資料和邏輯檢視名
- }
- }
①可以通過在一個POJO類上放置@Controller或@RequestMapping,即可把一個POJO類變身為處理器;
②@RequestMapping(value="/login.do")請求URL(/login.do)到處理器的功能處理方法的對映;
③模型資料和邏輯檢視名的返回。
現在的處理器無需實現/繼承任何介面/類,只需要在相應的類/方法上放置相應的註解說明下即可。
2、spring配置檔案springMVC.xml
[html] view plain copy
- <!-- 發現無需下面處理器也可 -->
- <!--
- <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping"></bean>
- <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"></bean>
- -->
- <!-- 處理器 -->
- <bean class="com.itmyhome.Login"></bean>
- <!-- 定義跳轉的檔案的前後綴 -->
- <bean id="viewResolver"
- class="org.springframework.web.servlet.view.InternalResourceViewResolver">
- <property name="prefix" value="/" /> <!-- 預設放在WebRoot下 -->
- <property name="suffix" value=".jsp" />
- </bean>
3、檢視頁面(login.jsp)
[html] view plain copy
- <body>
- ${message }
- </body>
二、處理器定義
1、@Controller
- @Controller
- public class Login{
- ...
- }
2、@RequestMapping
[java] view plain copy
- @RequestMapping
- public class Login{
- ...
- }
3、窄化請求對映
[java] view plain copy
- import org.springframework.stereotype.Controller;
- import org.springframework.web.bind.annotation.RequestMapping;
- import org.springframework.web.servlet.ModelAndView;
- @Controller
- @RequestMapping(value="/login.do") //①處理器的通用對映字首
- public class Login{
- @RequestMapping(value="/login2.do") //②相對於①處的對映進行窄化
- public ModelAndView hello(){
- ...
- }
- }
此時URL就應該為:http://localhost:8080/springMVC/login/login2.do
三、請求對映
1、普通URL路徑對映
@RequestMapping(value={"/login.do","/user/login.do"}):多個URL路徑可以對映到同一個處理器的功能處理方法。
2、URL模板模式對映
@RequestMapping(value="/users/{userId}"):{xxx}佔位符,請求的URL可以是"/users/123456"或"/users/abcd"。
@RequestMapping(value="/users/{userId}/login.do"):這樣也是可以的,請求的URL可以是"/users/123/login.do"。
@RequestMapping(value="/users/{userId}/channel/{channelId}"):這樣也是可以的,請求的URL可以是"/users/123/channel/456"。
3、Ant風格的URL路徑對映
@RequestMapping(value="/users/**"):可以匹配"/users/abc/abc"。
@RequestMapping(value="/model?"):可匹配"/model1"或"/modela" ,但不匹配"/model"或"/modelaa";
@RequestMapping(value="/model*"):可匹配"/modelabc"或"/model",但不匹配"/modelabc/abc";
@RequestMapping(value="/model/*"):可匹配"/model/abc",但不匹配"/modelabc";
@RequestMapping(value="/model/**/{modelId}"):可匹配"/model/abc/abc/123”或"/model/123",
也就是Ant風格和URI模板變數風格可混用;
4、正則表示式風格的URL路徑對映
從Spring3.0開始支援正則表示式風格的URL路徑對映,格式為{變數名:正則表示式}
@RequestMapping(value="/login/{userId:\\d+}.do"):可以匹配
"/login/123.do",但不能匹配"/login/abc.do",這樣可以設計更加嚴格的規則。
5、組合使用是"或"的關係
如@RequestMapping(value={"/login.do","/user/login.do"})組合使用是或的關係,即"/login.do"或
"/user/login.do"請求URL路徑都可以對映到@RequestMapping指定的功能處理方法。