获取参数类型 一、基本类型参数 Controller 中业务方法的参数名称要与请求参数的name 一致,参数值会自动映射匹配。并且能自动做类型转换;自动的类型转换是指从String 向其他类型的转换。 http://localhost:8080/user/quick11?username=zhangsan&age=12 @RequestMapping(value = "/quick11") @ResponseBody public void save11(String username,int age) { System.out.println(username); System.out.println(age); } 二、获得POJO 类型参数 Controller 中业务方法的POJO参数的属性名与请求参数的name 一致,参数值会自动映射匹配。 http://localhost:8080/user/quick12?username=zhangsan&age=12 @RequestMapping(value = "/quick12") @ResponseBody public void save12(User user) throws IOException { System.out.println(user); } public class User { private String username; private int age; } 三、获得数组类型参数 Controller 中业务方法数组名称与请求参数的name 一致,参数值会自动映射匹配。 http://localhost:8080/user/quick13?strs=aaa&strs=bbb&strs=ccc @RequestMapping(value = "/quick13") @ResponseBody public void save13(String[] strs) { System.out.println(Arrays.asList(strs)); } 四、 获得集合类型参数1 获得集合参数时,要将集合参数包装到一个POJO 中才可以。 <form action="${pageContext.request.contextPath}/user/quick14" method="post"> <%--表明是第一个User对象的username age--%> <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="提交"> </form> @RequestMapping(value = "/quick14") @ResponseBody public void save14(VO vo) { System.out.println(vo); } public class VO { private List<User> userList; public List<User> getUserList() {return userList;} public void setUserList(List<User> userList) {this.userList = userList;} @Override public String toString() {return "VO{" + "userList=" + userList + '}';} } 五、获得集合类型参数2 当使用ajax 提交时,可以指定contentType 为json 形式,那么在方法参数位置使用@RequestBody 可以直接接收集合数据而无需使用POJO 进行包装。 Array userList = new Array(); userList.push({username: "zhangsan", age: 18}); userList.push({username: "lisi", age: 28}); @RequestMapping(value = "/quick15") @ResponseBody public void save15(@RequestBody List<User> userList) { System.out.println(userList); } 六、参数绑定注解@RequestParm @RequestParam 参数: value:请求参数名称 required:指定的请求参数是否必须包括,默认是true,提交时如果没有此参数则报错 defaultValue:当没有指定请求参数时,则使用指定的默认值赋值 @RequestMapping(value = "/quick16") @ResponseBody public void save16(@RequestParam(value = "name",required = false,defaultValue = "it") String username) { System.out.println(username); } 七、获得Restful 风格的参数 Restful 是一种软件架构风格、设计风格,而不是标准,只是提供了一组设计原则和约束条件。主要用于客户端和服务器交互类的软件,基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存机制等。 Restful 风格的请求是使用“url +请求方式” 表示一次请求目的的,HTTP 协议里面四个表示操作方式的动词如下: GET:用于获取资源(/user/1 GET:得到id = 1 的user) POST:用于新建资源(/user/1 POST:新增user) PUT:用于更新资源(/user/1 PUT:更新id = 1 的user) DELETE:用于删除资源(/user/1 DELETE:删除id = 1 的user) 上述url 地址/user/1 中的1就是要获得的请求参数,在SpringMVC 中可以使用占位符进行参数绑定。地址/user/1 可以写成/user/{id},占位符{id} 对应的就是1的值。 在业务方法中我们可以使用@PathVariable 注解进行占位符的匹配获取工作。 http://localhost:8080/user/quick19/zhangsan @RequestMapping(value = "/quick19/{name}") @ResponseBody public void save19(@RequestParam(value = "name",required = true) String username) { System.out.println(username); } 八、获得Servlet 相关API SpringMVC 支持使用原始ServletAPI对象 作为控制器方法的参数进行注入,常用的对象: HttpServletRequest HttpServletResponse HttpSession @RequestMapping(value = "/quick19") @ResponseBody public void save19(HttpServletRequest request, HttpServletResponse response, HttpSession session) { System.out.println(request); System.out.println(response); System.out.println(session); } 九、获得请求头 1. @RequestHeader 使用@RequestHeader 可以获得请求头信息,相当于web 阶段学习的request.getHeader(name) 属性: value:请求头的名称 required:是否必须携带此请求头 @RequestMapping(value = "/quick20") @ResponseBody public void save20(@RequestHeader(value = "User-Agent", required = false) String user_agent) throws IOException { System.out.println(user_agent); } 2. @CookieValue 使用@CookieValue 可以获得指定Cookie 的值 属性: value:指定cookie的名称 required:是否必须携带此请求头 @RequestMapping(value = "/quick21") @ResponseBody public void save21(@CookieValue(value = "JSESSIONID") String jsessionId) throws IOException { System.out.println(jsessionId); }