1. 程式人生 > >springMVC3學習(十)--註解式控制器

springMVC3學習(十)--註解式控制器

Spring2.5引入註解式處理器支援,通過@Controller和@RequestMapping註解定義

我們的處理器類。並且提供了一組強大的註解

需要通過處理器對映DefaultAnnotationHandlerMapping和處理器介面卡AnnotationMethodHandlerAdapter

來開啟支援@Controller和@RequestMapping註解的處理器。

@Controller:用於標識是處理器類;

@RequestMapping:請求到處理器功能方法的對映規則;

@RequestParam:請求引數到處理器功能處理方法的方法引數上的繫結;

@ModelAttribute:請求引數到命令物件的繫結;

@InitBinder:自定義資料繫結註冊支援,用於將請求引數轉換到命令物件屬性的對應型別;

一、簡單例子

1、控制器實現

[java]  view plain  copy   在CODE上檢視程式碼片 派生到我的程式碼片
  1. import javax.servlet.http.HttpServletRequest;  
  2. import javax.servlet.http.HttpServletResponse;  
  3. import org.springframework.stereotype.Controller;  
  4. import org.springframework.web.bind.annotation.RequestMapping;  
  5. import org.springframework.web.servlet.ModelAndView;  
  6. @Controller                                        
    //①將一個POJO類宣告為處理器  
  7. public class Login{  
  8.       
  9.     @RequestMapping(value="/login.do")              //②請求URL到處理器功能處理方法的對映  
  10.     public ModelAndView hello(HttpServletRequest request,HttpServletResponse response){  
  11.         ModelAndView mv = new ModelAndView();   
  12.         mv.addObject("message""Hello World!");   
  13.         //設定邏輯檢視名,檢視解析器會根據該名字解析到具體的檢視頁面  
  14.         mv.setViewName("login");   
  15.         return mv;                                  //③模型資料和邏輯檢視名  
  16.     }  
  17. }  

①可以通過在一個POJO類上放置@Controller或@RequestMapping,即可把一個POJO類變身為處理器;

②@RequestMapping(value="/login.do")請求URL(/login.do)到處理器的功能處理方法的對映;

③模型資料和邏輯檢視名的返回。

現在的處理器無需實現/繼承任何介面/類,只需要在相應的類/方法上放置相應的註解說明下即可。

2、spring配置檔案springMVC.xml

[html]  view plain  copy   在CODE上檢視程式碼片 派生到我的程式碼片
  1. <!-- 發現無需下面處理器也可 -->  
  2. <!--   
  3. <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping"></bean>  
  4. <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"></bean>  
  5.  -->  
  6.   
  7. <!-- 處理器 -->  
  8. <bean class="com.itmyhome.Login"></bean>  
  9.   
  10. <!-- 定義跳轉的檔案的前後綴 -->  
  11. <bean id="viewResolver"  
  12.     class="org.springframework.web.servlet.view.InternalResourceViewResolver">  
  13.     <property name="prefix" value="/" />  <!-- 預設放在WebRoot下 -->  
  14.     <property name="suffix" value=".jsp" />  
  15. </bean>  

3、檢視頁面(login.jsp)

[html]  view plain  copy   在CODE上檢視程式碼片 派生到我的程式碼片
  1. <body>  
  2.   ${message }  
  3. </body>  

二、處理器定義

1、@Controller 

[java]  view plain  copy   在CODE上檢視程式碼片 派生到我的程式碼片
  1. @Controller                                 
  2. public class Login{  
  3.    ...    
  4. }  
推薦使用這種方式宣告處理器,它和我們的@Service、@Repository很好的對應了我們常見的三層開發架構的元件。

2、@RequestMapping

[java]  view plain  copy   在CODE上檢視程式碼片 派生到我的程式碼片
  1. @RequestMapping  
  2. public class Login{  
  3.    ...    
  4. }  
這種方式也是可以的,但如果在類上使用@RequestMapping註解一般是用於窄化功能處理方法的對映的詳見下面

3、窄化請求對映

[java]  view plain  copy   在CODE上檢視程式碼片 派生到我的程式碼片
  1. import org.springframework.stereotype.Controller;  
  2. import org.springframework.web.bind.annotation.RequestMapping;  
  3. import org.springframework.web.servlet.ModelAndView;  
  4. @Controller                                          
  5. @RequestMapping(value="/login.do")  //①處理器的通用對映字首  
  6. public class Login{  
  7.       
  8.     @RequestMapping(value="/login2.do")   //②相對於①處的對映進行窄化  
  9.     public ModelAndView hello(){  
  10.          ...  
  11.     }  
  12. }  

此時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指定的功能處理方法。