1、 @RequestMapping
@RequestMapping除了修饰方法, 还可来修饰类
1). 类定义处: 提供初步的请求映射信息。相对于 WEB 应用的根目录
2). 方法处: 提供进一步的细分映射信息。 相对于类定义处的 URL。若类定义处未标注 @RequestMapping,则方法处标记的 URL相对于 WEB 应用的根目录
@RequestMapping("/testRequestMapping")
public String testRequestMapping() {
System.out.println("testRequestMapping");
return SUCCESS;
}
定义的类没有标注@RequestMapping:
<a href="testRequestMapping">Test RequestMapping</a>
定义的类标注@RequestMapping:(若类标注为:/springmvc)
<a href="springmvc/testRequestMapping">Test RequestMapping</a>
2、常用: 使用 method 属性来指定请求方式
REST包含GET,POST,PUT,DELETE
@RequestMapping(value = "/testMethod", method = RequestMethod.POST)
public String testMethod() {
System.out.println("testMethod");
return SUCCESS;
}
3、了解: 可以使用 params 和 headers 来更加精确的映射请求. params 和 headers 支持简单的表达式.
@RequestMapping(value = "testParamsAndHeaders", params = { "username",
"age!=10" }, headers = { "Accept-Language=en-US,zh;q=0.8" })
public String testParamsAndHeaders() {
System.out.println("testParamsAndHeaders");
return SUCCESS;
}
4、@RequestMapping还可以用@PathVariable来映射 URL 中的占位符到目标方法的参数中.
@RequestMapping("/testPathVariable/{id}")
public String testPathVariable(@PathVariable("id") Integer id) {
System.out.println("testPathVariable: " + id);
return SUCCESS;
}
<a href="mySpringMVCTest/testPathVariable/1">Test PathVariable</a>
@RequestMapping还支持Ant风格的URL
-?:匹配文件名中的一个字符
-*:匹配文件名中的任意字符
-**:匹配多层路劲 (包括直接忽略当前层)
@RequestMapping("/testAntPath/**/abc")
public String testAntPath() {
System.out.println("testAntPath");
return SUCCESS;
}
<a href="mySpringMVCTest/testAntPath/abc">Test AntPath</a>
<a href="mySpringMVCTest/testAntPath/abc/abc">Test AntPath</a>
5、REST风格URL
Rest 风格的 URL. 以 CRUD 为例:
新增: /order POST 修改: /order/1 PUT update?id=1
获取:/order/1 GET get?id=1 删除: /order/1 DELETE delete?id=1
如何发送 PUT 请求和 DELETE 请求呢 ?
1. 需要配置 HiddenHttpMethodFilter
2. 需要发送 POST 请求
3. 需要在发送 POST 请求时携带一个 name="_method" 的隐藏域, 值为 DELETE 或 PUT
在 SpringMVC 的目标方法中如何得到 id 呢? 使用 @PathVariable 注解
@RequestMapping(value = "/testRest/{id}", method = RequestMethod.PUT)
public String testRestPut(@PathVariable Integer id) {
System.out.println("testRest Put: " + id);
return SUCCESS;
}
<form action="mySpringMVCTest/testRest/1" method="post">
<input type="hidden" name="_method" value="PUT"/>
<input type="submit" value="TestRest PUT"/>
</form>
6、@RequestParam 来映射请求参数. value 值即请求参数的参数名 required 该参数是否必须. 默认为 true defaultValue 请求参数的默认值
@RequestMapping(value = "/testRequestParam")
public String testRequestParam(
@RequestParam(value = "username") String un,
@RequestParam(value = "age", required = false, defaultValue = "0") int age) {
System.out.println("testRequestParam, username: " + un + ", age: " + age);
return SUCCESS;
}
<a href="springmvc/testRequestParam?username=atguigu&age=11">Test RequestParam</a>
7、了解: 映射请求头信息 用法同 @RequestParam
@RequestMapping("/testRequestHeader")
public String testRequestHeader(
@RequestHeader(value = "Accept-Language") String al) {
System.out.println("testRequestHeader, Accept-Language: " + al);
return SUCCESS;
}
8、了解: @CookieValue: 映射一个 Cookie 值. 属性同 @RequestParam
@RequestMapping("/testCookieValue")
public String testCookieValue(@CookieValue("JSESSIONID") String sessionId) {
System.out.println("testCookieValue: sessionId: " + sessionId);
return SUCCESS;
}
9、Spring MVC 会按请求参数名和 POJO 属性名进行自动匹配, 自动为该对象填充属性值。支持级联属性。如:dept.deptId、dept.address.tel 等
@RequestMapping("/testPojo")
public String testPojo(User user) {
System.out.println("testPojo: " + user);
return SUCCESS;
}
10、可以使用 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;
}
注意:
1、@PathVariable注解是获取URL中的参数,@RequestParam是获取Request域中的对象。
2、视图中获取request域中对象:names: ${requestScope.names }
原文:http://www.cnblogs.com/huy360/p/4510634.html