1.@RequestMapping用于处理请求地址映射,可以作用于类和方法上
- SpringMVC使用@RequestMapping注解为控制器指定可以处理哪些URL请求
- 注解可标注的位置:在控制器的类定义及方法定义处都可标注@RequestMapping
(1)类定义处:对当前Handler中的所有的方法都起作用,相当于初步的请求映射
(2)方法处:对当前的方法起作用,提供进一步的细分映射信息。
(3)类定义+方法处:请求处理方法的请求映射变成:类定义处+方法定义处
- DispathcerServlet截取请求后,就通过控制器上@RequestMapping提供的映射信息确定请求所对应的处理方法。
- @RequestMapping注解的属性
① value: 默认属性,用于映射请求URL
② method: 用于映射请求方式(GET或者POST).
③ params: 用于映射请求参数
•params 支持简单的表达式:
④ headers:用于映射请求头信息
@RequestMapping("/hello")
@Controller
public class TestRequestMappingHandler {
@RequestMapping(value="/testRequestMapping",method=RequestMethod.GET,
params={"userName=tom","age=22"},headers={"Accept-Language=zh-CN,zh;q=0.9"})
public String testRequestmapping(){
return "success";
}
}
请求URL:http://localhost:8080/SpringMVC1/hello/testRequestMapping?userName=tom&age=22
2.@PathVariable映射URL绑定的占位符
- 带占位符的URL是Spring3.0新增的功能,该功能在SpringMVC向REST目标挺进发展过程中具有里程碑的意义
- 通过@PathVariable可以将URL中占位符参数绑定到控制器处理方法的入参中:URL 中的 {xxx} 占位符可以通过 @PathVariable("xxx") 绑定到操作方法的入参中
-
//rest风格 @PathVariable 映射URL绑定的占位符 //URL中的{xxx}占位符可以通过@PathVariable(“xx”)绑定到操作方法的入参中 @RequestMapping("/testPathVariable/{username}/{id}")//{username}/{id}占位符 public String testPathVariable(@PathVariable("username")String username,@PathVariable("id")Integer id){ System.out.println(username+" "+id); return "success"; }
请求URL:http://localhost:8080/SpringMVC1/hello/testPathVariable/tom/1001
3.@RequstParam绑定请求参数值
- 在处理方法的入参处使用@RequestParam可以把请求参数传递给请求方
- value:参数名
- required:是否必须。默认为 true, 表示请求参数中必须包含对应的参数,若不存在,将抛出异常
-
//RequestParam 绑定请求参数值 可以把请求参数值传递给请求方法 /*处理请求参数,将请求中的请求参数映射到方法的形参中 * defaultValue设置默认值,默认情况下 Spring会给请求中没有值的参数设置一个null值, * 如果设置了该值,required=true将失效,自动为false 如果没有传递该参数,就使用默认值 */ @RequestMapping("/testRequestParam") public String testRequestParam(@RequestParam("userName")String username,@RequestParam(value="age",required=true ,defaultValue="0")int age){ System.out.println("username:"+username+", age:"+age); return "success"; }
请求URL:http://localhost:8080/SpringMVC1/hello/testRequestParam?userName=Tom&age
4.@RequestHeader绑定请求报头的属性值
- 请求头包含了若干个属性,服务器可据此获知客户端的信息,通过 @RequestHeader 即可将请求头中的属性值绑定到处理方法的形参中,也有required、defaultValue等属性
5.@CookieValue绑定请求中的Cookie值
- 获取请求中的cookie信息,将请求中的cookie信息映射到请求处理方法的形参中
-
请求URL:http://localhost:8080/SpringMVC1/hello/testCookieValue//@CookieValue:获取请求中的cookie信息,将请求中的cookie信息映射到请求处理方法的形参中 @RequestMapping("/testCookieValue") public String testCookieValue(@CookieValue(value="JSESSIONID")String sessionid){ System.out.println("sessionid "+sessionid); return "success"; }
6..@SessionAttributes:将数据放到session中
① 该注解只能加到类上。
注解中有两个属性: String [] value Class[] types
② value: 通过指定模型数据key的方式将对应的数据存放到session对象中(如果有多个key,各个key之间用逗号隔开
③ types: 通过指定模型数据类型的方式将对应的数据存放到session对象中
默认情况下Spring MVC将模型中的数据存储到request域中。当一个请求结束后,数据就失效了。如果要跨页面使用。那么需 要使用到session。而@SessionAttributes注解就可以使得模型中的数据存储一份到session域中。配合@ModelAttribute("user")使用的时候,会将对应的名称的model值存到session中,
@SessionAttributes(value = { "user", "objUser" }, types = { String.class, User.class })
@Controller
public class SpringmvcHandler {
@RequestMapping("/testSessionAttributes")
public String testSessionAttributes(Map<String, Object> map) {
map.put("user", "LoginUser");
map.put("objUser", new User("Admin", "0515"));
return "success";
}
}
第一次访问其他handler,session中不存在属性user和objUser的值
第二次访问本handler ,session中存在属性user和objUser的值,这是因为访问本handler后,model数据就保存到了session中,在success页面就可以直接获取到了
7@ModelAttribute: 方法入参标注该注解后, 入参的对象就会放到数据模型中
页面不对password进行修改
/*@ModelAttribute注解标注的方法会在每一个@RequestMapping标注的方法之前执行
* 将确定好的User对象与请求中提交的数据进行整合。最终将User对象传入到请求处理方法中
*
*/
@ModelAttribute
public void getUser(@RequestParam(value="id",required=false)Integer
id,Map<String,Object> map){
//用户名 密码 邮箱 年龄
User user = new User(1001,"Admin","12312","45655555@qq.com",22);
System.out.println(user);
map.put("user", user);
}
@RequestMapping("/testModelAttribute")
public String testModelAttribute(User user) {
System.out.println("修改后"+user);
return "success";
}
如果没有@ModelAttribute注解,页面进行修改提交后(不修改password),handler中获取到的user 为
User [id=1001, username=zcy, password=null, email=zcy@sina.com, age=27] 可看到此结果中password=null
加上@ModelAttribute注解后,@ModelAttribute注解标注的方法会在每一个@RequestMapping标注的方法之前执行.将确定好的User对象与请求中提交的数据进行整合。最终将User对象传入到请求处理方法最终将User对象传入到请求处理方法
User [id=1001, username=zcy, password=12312, email=zcy@sina.com, age=27]
8.@RequestBody 和@ResponseBody