到目前為止,請求已經能交給我們的處理器進行處理了,接下來的事情是要進行收集資料啦,接下來我們看看我們能從請求中收集到哪些資料

1、@RequestParam綁定單個請求參數值;
2、@PathVariable綁定URI模闆變量值;
3、@CookieValue綁定Cookie資料值
4、@RequestHeader綁定請求頭資料;
5、@ModelValue綁定參數到指令對象;
6、@SessionAttributes綁定指令對象到session;
7、@RequestBody綁定請求的内容區資料并能進行自動類型轉換等。
8、@RequestPart綁定“multipart/data”資料,除了能綁定@RequestParam能做到的請求參數外,還能綁定上傳的檔案等。
除了上邊提到的注解,我們還可以通過如HttpServletRequest等API得到請求資料,但推薦使用注解方式,因為使用起來更簡單。
功能處理方法支援的參數類型
在繼續學習之前,我們需要首先看看功能處理方法支援哪些類型的形式參數,以及他們的具體含義。
1. ServletRequest/HttpServletRequest 和 ServletResponse/HttpServletResponse
public String requestOrResponse (
ServletRequest servletRequest, HttpServletRequest httpServletRequest,
ServletResponse servletResponse, HttpServletResponse httpServletResponse
)
Spring Web MVC架構會自動幫助我們把相應的Servlet請求/響應(Servlet API)作為參數傳遞過來。
- 、InputStream/OutputStream 和 Reader/Writer
public void inputOrOutBody(InputStream requestBodyIn, OutputStream responseBodyOut)
throws IOException {
responseBodyOut.write("success".getBytes());
}
requestBodyIn:擷取請求的内容區位元組流,等價于request.getInputStream();
responseBodyOut:擷取相應的内容區位元組流,等價于response.getOutputStream()。
public void readerOrWriteBody(Reader reader, Writer writer)
throws IOException {
writer.write("hello");
}
reader:擷取請求的内容區字元流,等價于request.getReader();
writer:擷取相應的内容區字元流,等價于response.getWriter()。
InputStream/OutputStream 和 Reader/Writer兩組不能同時使用,隻能使用其中的一組。
- HttpSession
public String session(HttpSession session) {
System.out.println(session);
return "success";
}
此處的session永遠不為null。
注意:session通路不是線程安全的,如果需要線程安全,需要設定AnnotationMethodHandlerAdapter或RequestMappingHandlerAdapter的synchronizeOnSession屬性為true,即可線程安全的通路session。
-
指令/表單對象
Spring Web MVC能夠自動将請求參數綁定到功能處理方法的指令/表單對象上。
@RequestMapping(value = "/commandObject", method = RequestMethod.GET)
public String toCreateUser(HttpServletRequest request, UserModel user) {
return "customer/create";
}
@RequestMapping(value = "/commandObject", method = RequestMethod.POST)
public String createUser(HttpServletRequest request, UserModel user) {
System.out.println(user);
return "success";
}
如果送出的表單(包含username和password文本域),将自動将請求參數綁定到指令對象user中去。
-
Model、Map、ModelMap
Spring Web MVC 提供Model、Map或ModelMap讓我們能去暴露渲染視圖需要的模型資料。
@RequestMapping(value = "/model")
public String createUser(Model model, Map model2, ModelMap model3) {
model.addAttribute("a", "a");
model2.put("b", "b");
model3.put("c", "c");
System.out.println(model == model2);
System.out.println(model2 == model3);
return "success";}
雖然此處注入的是三個不同的類型(Model model, Map model2, ModelMap model3),但三者是同一個對象
AnnotationMethodHandlerAdapter和RequestMappingHandlerAdapter将使用BindingAwareModelMap作為模型對象的實作,即此處我們的形參(Model model, Map model2, ModelMap model3)都是同一個BindingAwareModelMap執行個體。
@RequestMapping(value = "/mergeModel")
public ModelAndView mergeModel(Model model) {
model.addAttribute("a", "a");//①添加模型資料
ModelAndView mv = new ModelAndView("success");
mv.addObject("a", "update");//②在視圖渲染之前更新③處同名模型資料
model.addAttribute("a", "new");//③修改①處同名模型資料
//視圖頁面的a将顯示為"update" 而不是"new"
return mv;
}
Errors/BindingResult
@RequestMapping(value = "/error1")
public String error1(UserModel user, BindingResult result)
@RequestMapping(value = "/error2")
public String error2(UserModel user, BindingResult result, Model model) {
@RequestMapping(value = "/error3")
public String error3(UserModel user, Errors errors)
其他雜項
public String other(Locale locale, Principal principal)