SpringMVC 獲得請求資料
獲得請求引數
客戶端請求引數的格式是:name=value&name=value… …
伺服器端要獲得請求的引數,有時還需要進行資料的封裝,SpringMVC可以接收如下型別的引數:
-
基本型別引數
-
POJO型別引數
-
陣列型別引數
-
集合型別引數
獲得基本型別引數
Controller中的業務方法的引數名稱要與請求引數的name一致,引數值會自動對映匹配
http://localhost:8080/quick9?username=zhangsan&age=12
@RequestMapping("/quick9") @ResponseBody public void quickMethod9(String username,int age) throws IOException { System.out.println(username); System.out.println(age); }
獲得POJO型別引數
Controller中的業務方法的POJO引數的屬性名與請求引數的name一致,引數值會自動對映匹配
http://localhost:8080/quick10?username=zhangsan&age=12
public class User { private String username; private int age; getter/setter… } @RequestMapping("/quick10") @ResponseBody public void quickMethod10(User user) throws IOException { System.out.println(user); }
獲得陣列型別引數
Controller中的業務方法陣列名稱與請求引數的name一致,引數值會自動對映匹配。
http://localhost:8080/quick11?strs=111&strs=222&strs=333
@RequestMapping("/quick11")
@ResponseBody
public void quickMethod11(String[] strs) throws IOException {
System.out.println(Arrays.asList(strs));
}
獲得集合型別引數
- 獲得集合引數時,要將集合引數包裝到一個POJO中才可以。
<form action="${pageContext.request.contextPath}/quick12" method="post">
<input type="text" name="userList[0].username"><br>
<input type="text" name="userList[0].age"><br>
<input type="text" name="userList[1].username"><br>
<input type="text" name="userList[1].age"><br>
<input type="submit" value="提交"><br>
</form>
@RequestMapping("/quick12")
@ResponseBody
public void quickMethod12(Vo vo) throws IOException {
System.out.println(vo.getUserList());
}
- 當使用ajax提交時,可以指定contentType為json形式,那麼在方法引數位置使用@RequestBody可以直接接收集合資料而無需使用POJO進行包裝。
<script>
//模擬資料
var userList = new Array();
userList.push({username: "zhangsan",age: "20"});
userList.push({username: "lisi",age: "20"});
$.ajax({
type: "POST",
url: "/itheima_springmvc1/quick13",
data: JSON.stringify(userList),
contentType : 'application/json;charset=utf-8'
});
</script>
@RequestMapping("/quick13")
@ResponseBody
public void quickMethod13(@RequestBody List<User> userList) throws IOException {
System.out.println(userList);}
注意:出現沒有載入到jquery檔案的問題時,原因是SpringMVC的前端控制器DispatcherServlet的url-pattern配置的是/,代表對所有的資源都進行過濾操作,我們可以通過以下兩種方式指定放行靜態資源:
-
在spring-mvc.xml配置檔案中指定放行的資源
<mvc:resources mapping="/js/**" location="/js/"/>
-
使用<mvc:default-servlet-handler/>標籤
請求資料亂碼問題
當post請求時,資料會出現亂碼,我們可以設定一個過濾器來進行編碼的過濾。
<filter>
<filter-name>CharacterEncodingFilter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>CharacterEncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
引數繫結註解@requestParam
當請求的引數名稱與Controller的業務方法引數名稱不一致時,就需要通過@RequestParam註解顯示的繫結。
<form action="${pageContext.request.contextPath}/quick14" method="post">
<input type="text" name="name"><br>
<input type="submit" value="提交"><br>
</form>
@RequestMapping("/quick14")
@ResponseBody
public void quickMethod14(@RequestParam("name") String username) throws IOException {
System.out.println(username);
}
註解@RequestParam還有如下引數可以使用:
-
value:與請求引數名稱
-
required:此在指定的請求引數是否必須包括,預設是true,提交時如果沒有此引數則報錯
-
defaultValue:當沒有指定請求引數時,則使用指定的預設值賦值
@RequestMapping("/quick14")
@ResponseBody
public void quickMethod14(@RequestParam(value="name",required = false,defaultValue = "itcast") String username) throws IOException {
System.out.println(username);
}
自定義型別轉換器
- 定義轉換器類實現Converter介面
public class DateConverter implements Converter<String,Date>{
@Override
public Date convert(String source) {
SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
try {
Date date = format.parse(source);
return date;
} catch (ParseException e) {
e.printStackTrace();
}
return null;
}}
- 在配置檔案中宣告轉換器
<bean id="converterService"
class="org.springframework.context.support.ConversionServiceFactoryBean">
<property name="converters">
<list>
<bean class="com.converter.DateConverter"/>
</list>
</property>
</bean>
- 在<annotation-driven>中引用轉換器
<mvc:annotation-driven conversionservice="converterService"/>
獲得Servlet相關API
SpringMVC支援使用原始ServletAPI物件作為控制器方法的引數進行注入,常用的物件如下:
-
HttpServletRequest
-
HttpServletResponse
-
HttpSession
@RequestMapping("/quick16")
@ResponseBody
public void quickMethod16(HttpServletRequest request,HttpServletResponse response,HttpSession session){
System.out.println(request);
System.out.println(response);
System.out.println(session);
}
獲得請求頭
@RequestHeader
使用@RequestHeader可以獲得請求頭資訊,相當於web階段學習的request.getHeader(name)
@RequestHeader註解的屬性如下:
-
value:請求頭的名稱
-
required:是否必須攜帶此請求頭
@RequestMapping("/quick17")
@ResponseBody
public void quickMethod17(
@RequestHeader(value = "User-Agent",required = false) String headerValue){
System.out.println(headerValue);
}
@CookieValue
使用@CookieValue可以獲得指定Cookie的值
@CookieValue註解的屬性如下:
-
value:指定cookie的名稱
-
required:是否必須攜帶此cookie
@RequestMapping("/quick18")
@ResponseBody
public void quickMethod18(@CookieValue(value = "JSESSIONID",required = false) String jsessionid){
System.out.println(jsessionid);
}