@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()