5.1 请求处理方法签名
Spring MVC 通过分析处理方法的签名,HTTP请求信息绑定到处理方法的相应人参中。
Spring MVC 对控制器处理方法签名的限制是很宽松的,几乎可以按喜欢的任何方式对方法进行签名。
必要时可以对方法及方法入参标注相应的注解( @PathVariable 、@RequestParam、@RequestHeader 等)、
Spring MVC 框架会将 HTTP 请求的信息绑定到相应的方法入参中,并根据方法的返回值类型做出相应的后续处理。
5.2 @RequestParam
在处理方法入参处使用 @RequestParam 可以把请求参数传递给请求方法
value:参数名
required:是否必须。默认为 true, 表示请求参数中必须包含对应的参数,若不存在,将抛出异常
defaultValue: 默认值,当没有传递参数时使用该值
[
](https://blog.csdn.net/qq_43284469/article/details/111054162)
/**
* @RequestParam 注解用于映射请求参数
* value 用于映射请求参数名称
* required 用于设置请求参数是否必须的
* defaultValue 设置默认值,当没有传递参数时使用该值
*/
@RequestMapping(value="/testRequestParam")
public String testRequestParam(@RequestParam(value="username") String username,
@RequestParam(value="age",required=false,defaultValue="0") int age){
System.out.println("testRequestParam - username="+username +",age="+age);
return "success";
}
页面链接:
<!--测试 请求参数 @RequestParam 注解使用 -->
<a href="springmvc/testRequestParam?username=achang&age=10">testRequestParam</a>
PS:表单中的内部标签name值与@RequestParam的value相同也可以把内部标签的value赋值给标上@RequestParam注解的变量,讲算不写@RequestParam,参数也是默认写了@RequestParam。
5.3 @RequestHeader
- 使用 @RequestHeader 绑定请求报头的属性值
- 请求头包含了若干个属性,服务器可据此获知客户端的信息,通过 @RequestHeader 即可将请求头中的属性值绑定到处理方法的入参中
//了解: 映射请求头信息 用法同 @RequestParam
@RequestMapping(value="/testRequestHeader")
public String testRequestHeader(@RequestHeader(value="Accept-Language") String al){
System.out.println("testRequestHeader - Accept-Language:"+al);
return "success";
}
<!-- 测试 请求头@RequestHeader 注解使用 -->
<a href="springmvc/testRequestHeader">testRequestHeader</a>
5.4 @CookieValue
- 使用 @CookieValue 绑定请求中的 Cookie 值
- @CookieValue 可让处理方法入参绑定某个 Cookie 值
//了解:@CookieValue: 映射一个 Cookie 值. 属性同 @RequestParam
@RequestMapping("/testCookieValue")
public String testCookieValue(@CookieValue("JSESSIONID") String sessionId) {
System.out.println("testCookieValue: sessionId: " + sessionId);
return "success";
}
5.5 使用POJO作为参数
- 使用 POJO 对象绑定请求参数值
- Spring MVC 会按请求参数名和 POJO 属性名进行自动匹配,自动为该对象填充属性值。支持级联属性。如:dept.deptId、dept.address.tel 等
```java
/**
- Spring MVC 会按请求参数名和 POJO 属性名进行自动匹配, 自动为该对象填充属性值。
- 支持级联属性
- 如:dept.deptId、dept.address.tel 等 */ @RequestMapping(“/book”) public String addBook(Book book) { System.out.println(book); return “success”; }
<br />表单页面:<br />
<a name="fFft0"></a>
## 5.6 解决乱码
如果中文有乱码,需要配置字符编码过滤器,且配置在其他过滤器之前(即要最先配置),如(HiddenHttpMethodFilter),否则不起作用。(思考method=”get”请求的乱码问题怎么解决的)
```xml
<!-- 配置字符集 -->
<filter>
<filter-name>encodingFilter</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>forceEncoding</param-name>
<param-value>true</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>encodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
5.7 使用Servlet原生API作为参数
- MVC 的 Handler 方法可以接受哪些 ServletAPI 类型的参数
```java
/**
- 可以使用 Serlvet 原生的 API 作为目标方法的参数 具体支持以下类型
- HttpServletRequest
- HttpServletResponse
- HttpSession
- java.security.Principal
- Locale InputStream
- OutputStream
- Reader
- Writer
- @throws IOException */ @RequestMapping(“/testServletAPI”) public void testServletAPI(HttpServletRequest request,HttpServletResponse response, Writer out) throws IOException { System.out.println(“testServletAPI, “ + request + “, “ + response); out.write(“hello springmvc”); //return “success”; }
```