获取请求参数
1、通过ServletAPI获取
将HttpServletRequest作为控制器方法的形参,此时HttpServletRequest类型的参数表示封装了当前请求的请求报文的对象
<a th:href="@{/httpServletRequest(username='admin',password=123456)}">测试servletRequest获取参数</a><br>
@RequestMapping("/httpServletRequest")
//形参位置的request表示当前请求
public String httpServletRequest(HttpServletRequest request){
String username = request.getParameter("username");
String password = request.getParameter("password");
System.out.println("username:"+username+",password:"+password);
return "success";
}
控制台输出结果:
username:admin,password:123456
2、通过控制器方法的形参获取请求参数
在控制器方法的形参位置,设置和请求参数同名的形参,当浏览器发送请求,匹配到请求映射时,在DispatcherServlet中就会将请求参数赋值给相应的形参
<a th:href="@{/dispatcherServlet(username='admin',password=123456)}">测试控制器DispatcherServlet形参获取参数</a><br>
@RequestMapping("/dispatcherServlet")
public String dispatcherServlet(String username, String password){
System.out.println("username:"+username+",password:"+password);
return "success";
}
控制台输出结果:username:admin,password:123456
或者表单,多个同名请求
<form th:action="@{/dispatcherServletMoreStr}" method="get">
用户名:<input type="text" name="username" value="张三"/><br>
密 码:<input type="password" name="password" value="123456"/><br>
爱好:<input type="checkbox" name="hobby" value="a">a
<input type="checkbox" name="hobby" value="b">b
<input type="checkbox" name="hobby" value="c">c<br>
<input type="submit" value="测试控制器形参获取多个同名参数-->String"/>
</form><br>
@RequestMapping("/dispatcherServletMoreStr")
//String
public String dispatcherServletMoreStr(String username, String password, String hobby) {
System.out.println("username:" + username + ",password:" + password + ",hobby:" + hobby);
return "success";
}
控制台输出结果:username:张三,password:123456,hobby:a,b,c
<form th:action="@{/dispatcherServletMoreStrArr}" method="get">
用户名:<input type="text" name="username" value="张三"/><br>
密 码:<input type="password" name="password" value="123456"/><br>
爱好:<input type="checkbox" name="hobby" value="a">a
<input type="checkbox" name="hobby" value="b">b
<input type="checkbox" name="hobby" value="c">c<br>
<input type="submit" value="测试控制器形参获取多个同名参数-->String[]"/>
</form><br>
@RequestMapping("/dispatcherServletMoreStrArr")
//String[]
public String dispatcherServletMoreStrArr(String username,String password,String[] hobby){
System.out.println("username:"+username+",password:"+password + ",hobby:"+ Arrays.toString(hobby));
return "success";
}
控制台输出结果:username:张三,password:123456,hobby:[a, b, c]
注:
若请求所传输的请求参数中有多个同名的请求参数,此时可以在控制器方法的形参中设置字符串数组或者字符串类型的形参接收此请求参数
若使用字符串数组类型的形参,此参数的数组中包含了每一个数据
若使用字符串类型的形参,此参数的值为每个数据中间使用逗号拼接的结果
3、@RequestParam
当我们请求参数里存在可传可不传的参数,又不能修改源码时,可以用此注解给参数修饰建立一一对应的映射关系,当不需要传此参数时,可设置默认值,避免报Spring错误。
@RequestParam是将请求参数和控制器方法的形参创建映射关系(与形参建立一一对应的映射关系)
@RequestParam注解一共有三个属性:
value:指定为形参赋值的请求参数的参数名
required:设置是否必须传输此请求参数,默认值为true
若设置为true时,则当前请求必须传输value所指定的请求参数,若没有传输该请求参数,且没有设置defaultValue属性,则页面报错400:Required String parameter ‘xxx’ is not present;若设置为false,则当前请求不是必须传输value所指定的请求参数,若没有传输,则注解所标识的形参的值为null
defaultValue:不管required属性值为true或false,当value所指定的请求参数没有传输或传输的值为""时,则使用默认值为形参赋值。
<form th:action="@{/requestParam}" method="get">
用户名:<input type="text" name="user_name" /><br>
密 码:<input type="password" name="password" value="123456"/><br>
爱好:<input type="checkbox" name="hobby" value="a">a
<input type="checkbox" name="hobby" value="b">b
<input type="checkbox" name="hobby" value="c">c<br>
<input type="submit" value="测试@RequestParam修饰参数"/>
</form><br>
@RequestMapping("/requestParam")
public String requestParam(
@RequestParam(value = "user_name", required = false, defaultValue = "张三") String username,
String password,
String[] hobby) {
System.out.println("username:" + username + ",password:" + password + ",hobby:" + Arrays.toString(hobby));
return "success";
}
当username不传实参时,采用默认值时,控制台输出结果:username:张三,password:123456,hobby:[a, b, c]
4、@RequestHeader
@RequestHeader是将请求头信息和控制器方法的形参创建映射关系
@RequestHeader注解一共有三个属性:value、required、defaultValue,用法同@RequestParam
<a th:href="@{/requestHeader(username='admin',password=123456)}">测试@RequestHeader</a><br>
@RequestMapping("/requestHeader")
public String requestHeader(
String username,
String password,
@RequestHeader(value = "Host",required = false,defaultValue = "localHost")String host) {
System.out.println("username:" + username + ",password:" + password);
System.out.println(host);
return "success";
}
控制台输出结果:
username:admin,password:123456
localhost:8080
5、@CookieValue
@CookieValue是将cookie数据和控制器方法的形参创建映射关系
@CookieValue注解一共有三个属性:value、required、defaultValue,用法同@RequestParam
<a th:href="@{/session}">开启会话,生成cookie</a><br>
<a th:href="@{/cookie}">测试cookie</a><br>
@RequestMapping("/session")
//先访问session生成会话,浏览器端才能生成cookie
public String session(HttpServletRequest request){
request.getSession();
return "success";
}
@RequestMapping("/cookie")
public String cookie(@CookieValue(value = "JSESSIONID",required = false,defaultValue = "JSESSIONID")String cookie) {
System.out.println("cookie:"+cookie);
return "success";
}
控制台输出结果:
cookie:B35D997ACFDCEA6AE8134A6440212841
6、通过POJO获取请求参数
可以在控制器方法的形参位置设置一个实体类类型的形参,此时若浏览器传输的请求参数的参数名和实体类中的属性名一致,那么请求参数就会为此属性赋值
<form th:action="@{/pojo}" method="post">
用户名:<input type="text" name="username" value="张三"><br>
密码:<input type="password" name="password" value="123456"><br>
性别:<input type="radio" name="sex" value="男" checked="checked">男<input type="radio" name="sex" value="女">女<br>
年龄:<input type="text" name="age" value="23"><br>
邮箱:<input type="text" name="email" value="123@qq.com"><br>
<input type="submit">
</form><br>
@RequestMapping("/pojo")
public String pojo(User user){
System.out.println(user);
return "success";
}
控制台输出结果:
User{id=null, username='??????', password='123456', age=23, sex='??·', email='123@qq.com'}
中文乱码问题,后面解决!
7、解决获取请求参数的乱码问题
解决获取请求参数的乱码问题,可以使用SpringMVC提供的编码过滤器CharacterEncodingFilter,但是必须在web.xml中进行注册(主要针对post请求)
<!--配置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>
注:
SpringMVC中处理编码的过滤器一定要配置到其他过滤器之前,否则无效
get请求乱码可以在tomcat配置文件server.xml中添加URIEnconding="UTF-8",一次性永久解决。 <Connector port="8080" URIEnconding="UTF-8" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" />
乱码处理后的结果:
User{id=null, username='张三', password='123456', age=23, sex='男', email='123@qq.com'}