SpringMVC常用注解整理

1.@RequestMapping用于处理请求地址映射,可以作用于类和方法上

  • SpringMVC使用@RequestMapping注解为控制器指定可以处理哪些URL请求
  • 注解可标注的位置:在控制器的类定义及方法定义处都可标注@RequestMapping

        (1)类定义处:对当前Handler中的所有的方法都起作用,相当于初步的请求映射

     (2)方法处:对当前的方法起作用,提供进一步的细分映射信息。

     (3)类定义+方法处:请求处理方法的请求映射变成:类定义处+方法定义处

  • DispathcerServlet截取请求后,就通过控制器上@RequestMapping提供的映射信息确定请求所对应的处理方法。
  • @RequestMapping注解的属性

      ①  value: 默认属性,用于映射请求URL

      ②  method: 用于映射请求方式(GET或者POST).

      ③  params: 用于映射请求参数

             •params 支持简单的表达式

param1: 表示请求必须包含名为 param1 的请求参数
!param1: 表示请求不能包含名为 param1 的请求参数
param1 != value1: 表示请求包含名为 param1 的请求参数,但其值不能为 value1
{“param1=value1”, “param2”}: 请求必须包含名为 param1 param2 的两个请求参数,且 param1 参数的值必须为 value1

      ④  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绑定的占位符

  •   带占位符的URLSpring3.0新增的功能,该功能在SpringMVCREST目标挺进发展过程中具有里程碑的意义
  • 通过@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信息映射到请求处理方法的形参中
  •    //@CookieValue:获取请求中的cookie信息,将请求中的cookie信息映射到请求处理方法的形参中
       @RequestMapping("/testCookieValue")
       public String testCookieValue(@CookieValue(value="JSESSIONID")String sessionid){
    	   System.out.println("sessionid "+sessionid);
    	   return "success";
       }
    请求URL:http://localhost:8080/SpringMVC1/hello/testCookieValue

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 

https://blog.csdn.net/lbqlzch/article/details/106178631

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值