Spring MVC學習(六)-------註解式控制器詳解4

到目前爲止,請求已經能交給咱們的處理器進行處理了,接下來的事情是要進行收集數據啦,接下來咱們看看咱們能從請求中收集到哪些數據,如圖6-11:java



 圖6-11web

一、@RequestParam綁定單個請求參數值;安全

二、@PathVariable綁定URI模板變量值;session

三、@CookieValue綁定Cookie數據值app

四、@RequestHeader綁定請求頭數據;框架

五、@ModelValue綁定參數到命令對象;ide

六、@SessionAttributes綁定命令對象到session;學習

七、@RequestBody綁定請求的內容區數據並能進行自動類型轉換等。測試

八、@RequestPart綁定「multipart/data」數據,除了能綁定@RequestParam能作到的請求參數外,還能綁定上傳的文件等。ui

 

除了上邊提到的註解,咱們還能夠經過如HttpServletRequest等API獲得請求數據,但推薦使用註解方式,由於使用起來更簡單。

 

接下來先看一下功能處理方法支持的參數類型吧。

6.6.一、功能處理方法支持的參數類型

在繼續學習以前,咱們須要首先看看功能處理方法支持哪些類型的形式參數,以及他們的具體含義。

 1、ServletRequest/HttpServletRequest 和 ServletResponse/HttpServletResponse

Java代碼   收藏代碼
  1. public String requestOrResponse (  
  2.         ServletRequest servletRequest, HttpServletRequest httpServletRequest,  
  3.         ServletResponse servletResponse, HttpServletResponse httpServletResponse  
  4.     )  
 Spring Web MVC框架會自動幫助咱們把相應的Servlet請求/響應(Servlet API)做爲參數傳遞過來。

 

2、InputStream/OutputStream 和 Reader/Writer

Java代碼   收藏代碼
  1. public void inputOrOutBody(InputStream requestBodyIn, OutputStream responseBodyOut)  
  2.         throws IOException {  
  3. responseBodyOut.write("success".getBytes());  
  4. }  
requestBodyIn 獲取請求的內容區字節流,等價於request.getInputStream();

responseBodyOut獲取相應的內容區字節流,等價於response.getOutputStream()。

 

Java代碼   收藏代碼
  1. public void readerOrWriteBody(Reader reader, Writer writer)  
  2.         throws IOException {  
  3.     writer.write("hello");  
  4. }  
  reader 獲取請求的內容區字符流,等價於request.getReader();

writer獲取相應的內容區字符流,等價於response.getWriter()。

 

InputStream/OutputStream 和 Reader/Writer兩組不能同時使用,只能使用其中的一組。

 

3、WebRequest/NativeWebRequest

WebRequest是Spring Web MVC提供的統一請求訪問接口,不只僅能夠訪問請求相關數據(如參數區數據、請求頭數據,但訪問不到Cookie區數據),還能夠訪問會話和上下文中的數據;NativeWebRequest繼承了WebRequest,並提供訪問本地Servlet API的方法。

Java代碼   收藏代碼
  1. public String webRequest(WebRequest webRequest, NativeWebRequest nativeWebRequest) {  
  2.     System.out.println(webRequest.getParameter("test"));//①獲得請求參數test的值  
  3.     webRequest.setAttribute("name""value", WebRequest.SCOPE_REQUEST);//②  
  4.     System.out.println(webRequest.getAttribute("name", WebRequest.SCOPE_REQUEST));  
  5.     HttpServletRequest request =   
  6.         nativeWebRequest.getNativeRequest(HttpServletRequest.class);//③  
  7.     HttpServletResponse response =   
  8.         nativeWebRequest.getNativeResponse(HttpServletResponse.class);  
  9.         return "success";  
  10.     }  
   webRequest.getParameter:訪問請求參數區的數據,能夠經過getHeader()訪問請求頭數據;

② webRequest.setAttribute/getAttribute:到指定的做用範圍內取/放屬性數據,Servlet定義的三個做用範圍分別使用以下常量表明:

            SCOPE_REQUEST :表明請求做用範圍;

           SCOPE_SESSION :表明會話做用範圍;

           SCOPE_GLOBAL_SESSION :表明全局會話做用範圍,即ServletContext上下文做用範圍。 

 nativeWebRequest.getNativeRequest/nativeWebRequest.getNativeResponse:獲得本地的Servlet API。

 

4、HttpSession

Java代碼   收藏代碼
  1. public String session(HttpSession session) {  
  2.     System.out.println(session);  
  3.     return "success";  
  4. }  
 此處的session永遠不爲null。

 

注意:session訪問不是線程安全的,若是須要線程安全,須要設置AnnotationMethodHandlerAdapter或RequestMappingHandlerAdapter的synchronizeOnSession屬性爲true,便可線程安全的訪問session。

 

5、命令/表單對象

Spring Web MVC可以自動將請求參數綁定到功能處理方法的命令/表單對象上。

Java代碼   收藏代碼
  1. @RequestMapping(value = "/commandObject", method = RequestMethod.GET)  
  2. public String toCreateUser(HttpServletRequest request, UserModel user) {  
  3.     return "customer/create";  
  4. }  
  5. @RequestMapping(value = "/commandObject", method = RequestMethod.POST)  
  6. public String createUser(HttpServletRequest request, UserModel user) {  
  7.     System.out.println(user);  
  8.     return "success";  
  9. }  
 若是提交的表單(包含username和password文本域),將自動將請求參數綁定到命令對象user中去。

 

6、Model、Map、ModelMap

Spring Web MVC 提供Model、Map或ModelMap讓咱們能去暴露渲染視圖須要的模型數據。

Java代碼   收藏代碼
  1. @RequestMapping(value = "/model")  
  2. public String createUser(Model model, Map model2, ModelMap model3) {  
  3.     model.addAttribute("a""a");  
  4.     model2.put("b""b");  
  5.     model3.put("c""c");  
  6.     System.out.println(model == model2);  
  7.     System.out.println(model2 == model3);  
  8.     return "success";}  

 雖然此處注入的是三個不一樣的類型(Model model, Map model2, ModelMap model3),但三者是同一個對象,如圖6-12所示:



6-11

AnnotationMethodHandlerAdapter和RequestMappingHandlerAdapter將使用BindingAwareModelMap做爲模型對象的實現,即此處咱們的形參(Model model, Map model2, ModelMap model3)都是同一個BindingAwareModelMap實例。

 

此處還有一點須要咱們注意:

Java代碼   收藏代碼
  1. @RequestMapping(value = "/mergeModel")  
  2. public ModelAndView mergeModel(Model model) {  
  3.     model.addAttribute("a""a");//①添加模型數據  
  4.     ModelAndView mv = new ModelAndView("success");  
  5.     mv.addObject("a""update");//②在視圖渲染以前更新③處同名模型數據  
  6.     model.addAttribute("a""new");//③修改①處同名模型數據  
  7.     //視圖頁面的a將顯示爲"update" 而不是"new"  
  8.     return mv;  
  9. }  
 從代碼中咱們能夠總結出功能處理方法的返回值中的模型數據(如ModelAndView)會 合併 功能處理方法形式參數中的模型數據(如Model),但若是二者之間有同名的,返回值中的模型數據會覆蓋形式參數中的模型數據。

 

7、Errors/BindingResult

Java代碼   收藏代碼
  1. @RequestMapping(value = "/error1")  
  2. public String error1(UserModel user, BindingResult result)  

 

Java代碼   收藏代碼
  1. @RequestMapping(value = "/error2")  
  2. public String error2(UserModel user, BindingResult result, Model model) {  
  3.       

 

Java代碼   收藏代碼
  1. @RequestMapping(value = "/error3")  
  2. public String error3(UserModel user, Errors errors)   

 

以上代碼都能獲取錯誤對象。

 

Spring3.1以前(使用AnnotationMethodHandlerAdapter)錯誤對象必須緊跟在命令對象/表單對象以後,以下定義是錯誤的:

Java代碼   收藏代碼
  1. @RequestMapping(value = "/error4")  
  2. public String error4(UserModel user, Model model, Errors errors)  
  3.     }  
如上代碼從Spring3.1開始(使用RequestMappingHandlerAdapter)將能正常工做,但仍是推薦「錯誤對象緊跟在命令對象/表單對象以後」,這樣是萬無一失的。

 

Errors及BindingResult的詳細使用請參考4.16.2數據驗證。

 

8、其餘雜項

Java代碼   收藏代碼
  1. public String other(Locale locale, Principal principal)  
  java.util.Locale:獲得當前請求的本地化信息,默認等價於ServletRequest.getLocale(),若是配置LocaleResolver解析器則由它決定Locale,後續介紹;

java.security.Principal該主體對象包含了驗證經過的用戶信息,等價於HttpServletRequest.getUserPrincipal()。

 

以上測試在cn.javass.chapter6.web.controller.paramtype.MethodParamTypeController中。

 

其餘功能處理方法的形式參數類型(如HttpEntity、UriComponentsBuilder、SessionStatus、RedirectAttributes)將在後續章節詳細講解。

 

第二部分會介紹註解方式的數據綁定。

相關文章
相關標籤/搜索