@RequestMapping 请求映射总结
注意:
@RequestMapping(“/helloworld”)
public String hello( HttpServletRequest request ,HttpServletResponse response){
System.out.println(“hello request” + request.toString());
System.out.println(“hello response” + response.toString());
return “success”;
}
handler 控制器:函数参数 可以有request和 response,可以有其中一个,也可以都没有,request和response 都是spring容器注入的。他们是接口。还有将request 和 response 内部对象 作为形参的 。另外也可以将 map【返回值ModelAndView中的model】作为形参。
经过了测试:如果 控制器的映射是这个–>@RequestMapping("/")
那么访问网站根目录时,还是以 网站根目录下的 index.jsp、 index.html 等做为结果 返回给浏览器。
一、请求映射-路径区分
1、请求映射-路径区分-基础
<a href="springmvc/testRequestMapping">Test RequestMapping</a>
package com.test.springmvc.handlers;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller // spring里面 又名handler 处理器
public class HelloWorld {
/**
* 1、使用RequestMapping 注解来映射 请求的url
* 2、返回值会通过视图解析器解析为实际的物理视图,
* 对于org.springframework.web.servlet.view.InternalResourceViewResolver
* 会做如下解析,prefix + returnVal + suffix 得到实际的物理视图。然后做转发操作。
* 即 WEB-INF/views/success.jsp
*/
@RequestMapping("/helloworld")
public String hello( HttpServletRequest request,HttpServletResponse response){
System.out.println("hello request" + request.toString());
System.out.println("hello response" + response.toString());
return "success";
}
}
2、请求映射-路径区分-利用post方式
<form action="springmvc/testMethod" method="POST">
<input type="submit" value="submit"/>
</form>
/**
* 常用: 使用 method 属性来指定请求方式
*/
@RequestMapping(value = "/testMethod", method = RequestMethod.POST)
public String testMethod() {
System.out.println("testMethod");
return "success";
}
3、请求映射-路径区分-利用请求参数和请求头
<a href="springmvc/testParamsAndHeaders?username=atguigu&age=10">Test ParamsAndHeaders</a>
/**
* 了解: 可以使用 params 和 headers 来更加精确的映射请求. params 和 headers 支持简单的表达式.
*
* @return
*/
@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、请求映射-路径区分-利用ant风格
Ant 风格资源地址支持3种匹配符:
?:匹配文件名中的一个字符
*:匹配一层路径
**:** 匹配多层路径
测试: <a href=”springmvc/testAntPath/mnxyz/abc”>Test AntPath</a>
@RequestMapping("/testAntPath/*/abc")
public String testAntPath() {
System.out.println("testAntPath");
return "success";
}
二、请求映射-信息传递
1、请求映射-信息传递-利用路径变量
测试: <a href=”springmvc/testPathVariable/1″>Test PathVariable</a>
/**
* @PathVariable 可以来映射 URL 中的占位符到目标方法的参数中.
* @param id
* @return
*/
@RequestMapping("/testPathVariable/{id}")
public String testPathVariable(@PathVariable("id") Integer id) {
System.out.println("testPathVariable: " + id);
return "success";
}
2、请求映射-信息传递-REST风格
示例:
/order/1 HTTP GET :得到id = 1的 order –
/order/1 HTTP DELETE:删除 id = 1 的 order –
/order/1 HTTP PUT:更新 id = 1的 order –
/order HTTP POST:新增 order –
HiddenHttpMethodFilter:浏览器 form 表单只支持 GET与POST请求,而DELETE、PUT 等method并不支持,Spring3.0 添加了一个过滤器,可以将这些请求转换为标准的 http 方法,使得支持 GET、POST、PUT 与DELETE 请求。
第一步:首先在web.xml的添加过滤器
<!--
配置 org.springframework.web.filter.HiddenHttpMethodFilter: 可以把 POST 请求转为 DELETE 或 POST 请求
-->
<filter>
<filter-name>HiddenHttpMethodFilter</filter-name>
<filter-class>org.springframework.web.filter.HiddenHttpMethodFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>HiddenHttpMethodFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
第二步:编写测试网页
<form action="springmvc/testRest/1" method="post">
<input type="hidden" name="_method" value="PUT"/>
<input type="submit" value="TestRest PUT"/>
</form>
<br><br>
<form action="springmvc/testRest/1" method="post">
<input type="hidden" name="_method" value="DELETE"/>
<input type="submit" value="TestRest DELETE"/>
</form>
<br><br>
<form action="springmvc/testRest" method="post">
<input type="submit" value="TestRest POST"/>
</form>
<br><br>
<a href="springmvc/testRest/1">Test Rest Get</a>
<br><br>
3、请求映射-信息传递-利用请求参数
/**
* @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>
其实也可以用表单的post方法,来传递请求参数,因为控制器也能解析的。
第三步:编写控制器
/**
* 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";
}
@RequestMapping(value = "/testRest/{id}", method = RequestMethod.DELETE)
public String testRestDelete(@PathVariable Integer id) {
System.out.println("testRest Delete: " + id);
return "success";
}
@RequestMapping(value = "/testRest", method = RequestMethod.POST)
public String testRest() {
System.out.println("testRest POST");
return "success";
}
@RequestMapping(value = "/testRest/{id}", method = RequestMethod.GET)
public String testRest(@PathVariable Integer id) {
System.out.println("testRest GET: " + id);
return "success";
}
4、请求映射-信息传递-利用请求头
测试: <a href=”springmvc/testRequestHeader”>Test RequestHeader</a>
/**
* 了解: 映射请求头信息 用法同 @RequestParam
*/
@RequestMapping("/testRequestHeader")
public String testRequestHeader(
@RequestHeader(value = "Accept-Language") String al) {
System.out.println("testRequestHeader, Accept-Language: " + al);
return "success";
}
5、请求映射-信息传递-利用cookie值
测试:<a href=”springmvc/testCookieValue”>Test CookieValue</a>
/**
* 了解:
*
* @CookieValue: 映射一个 Cookie 值. 属性同 @RequestParam
*/
@RequestMapping("/testCookieValue")
public String testCookieValue(@CookieValue("JSESSIONID") String sessionId) {
System.out.println("testCookieValue: sessionId: " + sessionId);
return "success";
}
6、请求映射-信息传递-form表单的pojo
将 表单信息 转换成 bean ,支持级联属性。如:dept.deptId、dept.address.tel 等
1、测试页:
<form action="springmvc/testPojo" method="post">
username: <input type="text" name="username"/>
<br>
password: <input type="password" name="password"/>
<br>
email: <input type="text" name="email"/>
<br>
age: <input type="text" name="age"/>
<br>
city: <input type="text" name="address.city"/>
<br>
province: <input type="text" name="address.province"/>
<br>
<input type="submit" value="Submit"/>
</form>
2、控制页
/**
* Spring MVC 会按请求参数名和 POJO 属性名进行自动匹配, 自动为该对象填充属性值。支持级联属性。
* 如:dept.deptId、dept.address.tel 等
*/
@RequestMapping("/testPojo")
public String testPojo(User user) {
System.out.println("testPojo: " + user);
return "success";
}
3、Bean [估计是调用默认构造函数,然后set属性,完成bean创建]
bean – user
public class User {
private Integer id;
private String username;
private String password;
private String email;
private int age;
private Address address;
public Integer getId() {
return id;
}
public void setId(Integer 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 getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public Address getAddress() {
return address;
}
public void setAddress(Address address) {
this.address = address;
}
public User() {}
}
bean-address
public class Address {
private String province;
private String city;
public String getProvince() {
return province;
}
public void setProvince(String province) {
this.province = province;
}
public String getCity() {
return city;
}
public void setCity(String city) {
this.city = city;
}
}
显示jsp页:
<%@ taglib uri=“http://java.sun.com/jsp/jstl/core” prefix=“c”%>
…
request user: ${requestScope.user }
核心摘要:在控制器中,自动生成的pojo的 User类型对象。会自动产生一个首字母小写的类型对象的关键字,并将关键字和其类型对象值,一同传入request中。
如这里:会将 “user” 作为关键字,user 对象作为value值,存放到request中。
操作和 request.setAttribute("user", user);一样
如果控制器的pojo参数用了 @ModelAttribute
注解标记,那么标记值若是XXX,则效果就像 request.setAttribute("XXX", user);一样
//举例如下:
//控制器中 用 @ModelAttribute 注解标记 的情况
public String testPojo(@ModelAttribute(value ="test") User user) {
System.out.println("testPojo: " + user);
return "success";
}
//在转发显示页 用 ${requestScope.test} 调用。当然别忘记添加 <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
总之一旦有pojo对象生成,那显示jsp页就可以直接调用${requestScope.标记名 }
7、请求映射-信息传递-原始servletapi作为参数
测试:<a href=”springmvc/testServletAPI”>Test ServletAPI</a>
/**
* 可以使用 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";
}
Handler的函数参数可以添加上面的这些,其实本质上来说:函数参数只有 request和response。其他的参数都是这些方法里面包括的。比如writer就是response.getWriter()