目录
1.通过ServletAPI获取
2.通过控制器方法的形参获取
3.@RequestParam:将请求参数和控制器方法的形参绑定
4.@RequestHeader:将请求头信息与控制器方法的形参的值进行绑定
Cookie:
编辑
6.通过控制器方法的实体类类型的形参获取请求参数
对应的index.html页面:
SpringMVC的处理流程:(用户请求-》Controller-》Model-》Controller-》View-》响应给用户)
用户通过视图层(View)发送请求到服务器,在服务器中请求被Controller接收,Controller调用相应的Model层处理请求,处理完毕将结果返回到Controller,Controller再根据请求处理的结果找到相应的View视图,渲染数据后最终响应给浏览器。
1.通过ServletAPI获取
只需要在控制器的方法的形参位置设置HTTPRequest request 类型的形参就i可以在控制器方法种使用request对象获取请求参数
@RequestMapping("/param/servletAPI")public String getParamServletAPI(HttpServletRequest request){HttpSession session = request.getSession();String username = request.getParameter("username");String password = request.getParameter("password");System.out.println("username = " + username + "," + "password = " + password);return "success";}
2.通过控制器方法的形参获取
只需要在控制器方法的形参位置设置一个形参,形参的名字和请求参数的名字保持一致即可
@RequestMapping("/param")public String getParam(String username, String password){System.out.println("username = " + username + "," + "password = " + password);return "success";}
3.@RequestParam:将请求参数和控制器方法的形参绑定
@RequestParam注解的三个属性:value,require,defaultValue
value:设置和形参绑定的请求参数的名字
required:设置是否必须传输value所对应得求情参数默认值为true,表示value所对应得请求参数必须传输,否则页面报错 ,或设置为false,则表示value所对应得请求参数不是必须传输,若为传输,则形参值为null
defaultValue:设置当没有传输value所对应得请求参数时,为形参设置得默认值,此时和required属性无关
@RequestMapping("/param")public String getParam(@RequestParam(value = "userName",required = true,defaultValue = "hello")String username, String password,){System.out.println("username = " + username + "," + "password = " + password);return "success";}
4.@RequestHeader:将请求头信息与控制器方法的形参的值进行绑定
@RequestMapping("/param")public String getParam(String username, String password,@RequestHeader("referer") String referer){System.out.println("username = " + username + "," + "password = " + password);System.out.println("referer = " + referer);return "success";}
5. CookieValue:将cookie数据和控制器方法的形参绑定
@RequestMapping("/param")public String getParam(String username, String password,@CookieValue("JSESSIONID") String jsessionId){System.out.println("username = " + username + "," + "password = " + password);System.out.println("jsessionId = " + jsessionId);return "success";}
Cookie:
6.通过控制器方法的实体类类型的形参获取请求参数
注意:需要在控制器方法的形参位置设置实体类类型的形参,要保证实体类的属性的属性名和请求参数的名字保持一致,可以通过实体类类型的形参获取请求参数
@RequestMapping("/param/pojo")public String getParamByPojo(User user){System.out.println(user);return "success";}
对应的index.html页面:
<h3>前五种方式实现:</h3>
<form th:action="@{/param}" method="get">用户名:<input type="text" name="username"><br>密码: <input type="password" name="password"><br><input type="submit" value="登录">
</form><h3>pojo实现:</h3>
<form th:action="@{/param/pojo}" method="get">用户名:<input type="text" name="username"><br>密码: <input type="password" name="password"><br><input type="submit" value="登录">
</form>
跳转页面:<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head><meta charset="UTF-8"><title>成功</title>
</head>
<body>
<h1>success.html</h1>
</body>
</html>