总结:SpringMVC获取请求参数的三种方式:
一:通过ServletAPI获取 将HttpServletRequest作为控制器方法的形参,此时HttpServletRequest类型的参数表示封装了当前请 求的请求报文的对象
二:通过控制器方法的形参获取请求参数 在控制器方法的形参位置,设置和请求参数同名的形参,当浏览器发送请求,匹配到请求映射时,在 DispatcherServlet中就会将请求参数赋值给相应的形参
三:通过POJO获取请求参数
可以在控制器方法的形参位置设置一个实体类类型的形参,此时若浏览器传输的请求参数的参数名和实 体类中的属性名一致,那么请求参数就会为此属性赋值
四、SpringMVC获取请求参数
1、通过ServletAPI获取 将HttpServletRequest作为控制器方法的形参,此时HttpServletRequest类型的参数表示封装了当前请 求的请求报文的对象
代码演示:
1.页面分发控制
@Controller
public class TestContorller {
@RequestMapping("/")//此处的/与web.xml文件中的<url-pattern>/</url-pattern> 一致
public String getindex(){
return "index";
}
@RequestMapping("/param")
public String to(){
return "testparam";
}
}
2跳转到:testparam.html
<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
<meta charset="UTF-8">
<title>测试请求参数</title>
</head>
<body>
<h1>测试请求参数</h1>
<a th:href="@{/paramServletAPI(username='amin',password=1234)}"> 测试使用servletAPI获取请求参数</a>
</body>
</html>
3.获取testparam.html的请求参数:
@Controller
public class ParamContorller {
@RequestMapping(value = {"/paramServletAPI"})
//形参位置:res表示当前请求
public String paramServletAPI(HttpServletRequest res){
String username = res.getParameter("username");
String password = res.getParameter("password");
System.out.println(username+"\t"+password);
return "success";跳转成功页面
}
}
4.success页面
<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
<meta charset="UTF-8">
<title>成功页面</title>
</head>
<body>
success
</body>
</html>
2、通过控制器方法的形参获取请求参数 在控制器方法的形参位置,设置和请求参数同名的形参,当浏览器发送请求,匹配到请求映射时,在 DispatcherServlet中就会将请求参数赋值给相应的形参
1.页面分发控制
@Controller
public class TestContorller {
@RequestMapping("/")//此处的/与web.xml文件中的<url-pattern>/</url-pattern> 一致
public String getindex(){
return "index";
}
@RequestMapping("/param")
public String to(){
return "testparam";
}
}
2跳转到:testparam.html
<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
<meta charset="UTF-8">
<title>测试请求参数</title>
</head>
<body>
<h1>测试请求参数</h1>
<a th:href="@{/paramServletAPI(username='amin',password=1234)}"> 测试使用servletAPI获取请求
参数</a>
<a th:href="@{/paramContor(id=123,name='sunchao',age=22)}">通过控制器方法的形参获取请求参数</a><br/>
</body>
</html>
3.获取testparam.html的请求参数:
//通过控制器方法的形参获取请求参数
@RequestMapping(value = {"/paramContor"})
public String paramContor(int id,String name,int age){
System.out.println(id);
System.out.println(name);
System.out.println(age);
return "success";
}
4.success页面
<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
<meta charset="UTF-8">
<title>成功页面</title>
</head>
<body>
success
</body>
</html>
注: 若请求所传输的请求参数中有多个同名的请求参数,此时可以在控制器方法的形参中设置字符串 数组或者字符串类型的形参接收此请求参数 若使用字符串数组类型的形参,此参数的数组中包含了每一个数据 若使用字符串类型的形参,此参数的值为每个数据中间使用逗号拼接的结果
代码演示:
1.testparam.html
<form th:action="@{/testParam}" method="post">
账户: <input type="text" name="name" ><br>
密码: <input type="password" name="password" ><br>
安好 <input type="checkbox" name="hobdy" value="a">a
<input type="checkbox" name="hobdy" value="b">b
<input type="checkbox" name="hobdy" value="c">c<br/>
<input type="submit" value="测试控制器的形参来回去参数">
</form>
2.
//若请求所传输的请求参数中有多个同名的请求参数,此时可以在控制器方法的形参中设置字符串 数组或者字符串类型的形参接收此请求参数 若使用字符串数组类型的形参,此参数的数组中包含了每一个数据 若使用字符串类型的形参,此参数的值为每个数据中间使用逗号拼接的结果
@RequestMapping(value = {"/testParam"})
public String testParam123(String name,String password,String hobdy){
System.out.println(name);
System.out.println(password);
System.out.println(hobdy);
return "success";
}
也可以如下:
//通过控制器方法的形参获取表单请求参数
@RequestMapping(value = {"/testParam"})
public String testParam123(String name,String password,String[] hobdy){
System.out.println(name);
System.out.println(password);
System.out.println(hobdy);
System.out.println(Arrays.toString(hobdy));
return "success";
}
3、@RequestParam
@RequestParam是将请求参数和控制器方法的形参创建映射关系
@RequestParam注解一共有三个属性:
value:指定为形参赋值的请求参数的参数名
<form th:action="@{/testParam}" method="post">
账户: <input type="text" name="username" ><br>
密码: <input type="password" name="password" ><br>
安好 <input type="checkbox" name="hobdy" value="a">a
<input type="checkbox" name="hobdy" value="b">b
<input type="checkbox" name="hobdy" value="c">c<br/>
<input type="submit" value="测试控制器的形参来回去参数">
</form>
//通过控制器方法的形参获取表单请求参数
@RequestMapping(value = {"/testParam"})
public String testParam123(@RequestParam("username")String name,String password,String[] hobdy){
System.out.println(name);
System.out.println(password);
System.out.println(hobdy);
System.out.println(Arrays.toString(hobdy));
return "success";
}
required:设置是否必须传输此请求参数,默认值为true 若设置为true时,则当前请求必须传输value所指定的请求参数,若没有传输该请求参数,且没有设置 defaultValue属性,则页面报错
400:Required String parameter 'xxx' is not present;若设置为 false,则当前请求不是必须传输value所指定的请求参数,若没有传输,则注解所标识的形参的值为 null
defaultValue:不管required属性值为true或false,当value所指定的请求参数没有传输或传输的值 为""时,则使用默认值为形参赋值
@RequestMapping("/testParam")
public String testParam(
@RequestParam(value = "user_name", required = false, defaultValue = "hehe") String username,
String password,
String[] hobby,
@RequestHeader(value = "sayHaha", required = true, defaultValue = "haha") String host,
@CookieValue("JSESSIONID") String JSESSIONID){
//若请求参数中出现多个同名的请求参数,可以再控制器方法的形参位置设置字符串类型或字符串数组接收此请求参数
//若使用字符串类型的形参,最终结果为请求参数的每一个值之间使用逗号进行拼接
System.out.println("username:"+username+",password:"+password+",hobby:"+ Arrays.toString(hobby));
System.out.println("host:"+host);
System.out.println("JSESSIONID:"+JSESSIONID);
return "success";
}
@RequestMapping(value = {"/testParam"})
public String testParam123(@RequestParam(value = "username",defaultValue = "sunchao")String name,String password,String[] hobdy){
System.out.println(name);
System.out.println(password);
System.out.println(hobdy);
System.out.println(Arrays.toString(hobdy));
return "success";
}
4、@RequestHeader
@RequestHeader是将请求头信息和控制器方法的形参创建映射关系
@RequestHeader注解一共有三个属性:value、required、defaultValue,用法同@RequestParam
5、@CookieValue
cookie是客户端的技术,主要存储服务器发给客户端的一些数据
@CookieValue是将cookie数据和控制器方法的形参创建映射关系
@CookieValue注解一共有三个属性:value、required、defaultValue,
用法同@RequestParam
//通过控制器方法的形参获取表单请求参数 @RequestMapping(value = {"/testParam"}) public String testParam123(@RequestParam(value = "username",defaultValue = "sunchao")String name, String password,String[] hobdy, @CookieValue("JSESSIONID") String session ){ System.out.println(name); System.out.println(password); System.out.println(hobdy); System.out.println(Arrays.toString(hobdy)); System.out.println(session); return "success"; }
6、通过POJO获取请求参数
可以在控制器方法的形参位置设置一个实体类类型的形参,此时若浏览器传输的请求参数的参数名和实 体类中的属性名一致,那么请求参数就会为此属性赋值
代码:
1.user对象
package com.sun.mvc.dao;
/**
* @author sunyc
* @create 2022-04-16 11:01
*/
public class User {
private int id;
private String username;
private String password;
private String sex;
private int age;
private String email;
public int getId() {
return id;
}
@Override
public String toString() {
return "User{" +
"id=" + id +
", username='" + username + '\'' +
", password='" + password + '\'' +
", sex='" + sex + '\'' +
", age=" + age +
", email='" + email + '\'' +
'}';
}
public void setId(int id) {
this.id = id;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}
}
2.testparam.html
<form th:action="@{/testpojo}" method="post">
用户名:<input type="text" name="username"><br>
密码:<input type="password" name="password"><br>
性别:<input type="radio" name="sex" value="男">男<input type="radio"
name="sex" value="女">女<br>
年龄:<input type="text" name="age"><br>
邮箱:<input type="text" name="email"><br>
<input type="submit">
</form>
3. //通过POJO获取请求参数
@RequestMapping(value = {"/testpojo"})
public String testpojo(User user){
System.out.println(user);
return "success";
}
7、解决获取请求参数的乱码问题 解决获取请求参数的乱码问题,可以使用SpringMVC提供的编码过滤器CharacterEncodingFilter,但是 必须在web.xml中进行注册
注: SpringMVC中处理编码的过滤器一定要配置到其他过滤器之前,否则无效
<!--配置springMVC的编码过滤器--> <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> <init-param> <param-name>forceResponseEncoding</param-name> <param-value>true</param-value> </init-param> </filter> <filter-mapping> <filter-name>CharacterEncodingFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>