springmvc:常用注解

一、RequestParam注解

作用:

  把请求中指定名称的参数给控制器中的形参赋值。

属性:

   value:请求参数中的名称。

  required:请求参数中是否必须提供此参数。默认值:true。表示必须提供,如果不提供将报错。

jsp中的代码:

1 <!-- requestParams注解的使用 -->
2 <a href="springmvc/useRequestParam?name=test">requestParam注解</a>
1     @RequestMapping("/testRequestParam")
2     public String testRequestParam(@RequestParam(name = "name") String username){
3         System.out.println("执行了。。。");
4         System.out.println(username);
5         return "success";
6     }


二、RequestBody注解

作用:

  用于获取请求体内容。直接使用得到是key=value&key=value...结构的数据。

  get请求方式不适用。

属性:

  required:是否必须有请求体。默认值是:true。当取值为true时,get请求方式会报错。如果取值为false,get请求得到是null。

 1 /**
 2      * 获取请求体的内容
 3      * @param body
 4      * @return
 5      */
 6     @RequestMapping("/testRequestBody")
 7     public String testRequestBody(@RequestBody String body){
 8         System.out.println("执行了。。。");
 9         System.out.println(body);
10         return "success";
11     }


三、PathVaribale注解

作用:

  用于绑定url中的占位符。例如:请求url中 /delete/{id},这个{id}就是url占位符。

  url支持占位符是spring3.0之后加入的。是springmvc支持rest风格URL的一个重要标志。

属性:

  value:用于指定url中占位符名称。

  required:是否必须提供占位符。

四、 HiddentHttpMethodFilter过滤器

作用:  

  由于浏览器 form 表单只支持 GET 与 POST 请求,而DELETE、PUT 等 method 并不支持,Spring3.0 添加了一个过滤器,可以将浏览器请求改为指定的请求方式,发送给我们的控制器方法,使得支持 GET、POST、PUT 与DELETE 请求。

使用方法:

  第一步:在web.xml中配置该过滤器。

  第二步:请求方式必须使用post请求。

  第三步:按照要求提供_method请求参数,该参数的取值就是我们需要的请求方式。

五、RequestHeader注解

作用:

  用于获取请求消息头。

属性:

  value:提供消息头名称

  required:是否必须有此消息头

注: 在实际开发中一般不怎么用。

六、CookieValue注解

作用:

  用于把指定cookie名称的值传入控制器方法参数。

属性:

  value:指定cookie的名称。

  required:是否必须有此cookie。

七、ModelAttribute

作用:

  该注解是SpringMVC4.3版本以后新加入的。它可以用于修饰方法和参数。

  出现在方法上,表示当前方法会在控制器的方法执行之前,先执行。它可以修饰没有返回值的方法,也可以修饰有具体返回值的方法。

  出现在参数上,获取指定的数据给参数赋值。

属性:

  value:用于获取数据的key。

  key可以是POJO的属性名称,也可以是map结构的key。

应用场景:

  当表单提交数据不是完整的实体类数据时,保证没有提交数据的字段使用数据库对象原来的数据。

  例如:我们在编辑一个用户时,用户有一个创建信息字段,该字段的值是不允许被修改的。在提交表单数据是肯定没有此字段的内容,一旦更新会把该字段内容置为null,此时就可以使用此注解解决问题。

八、SessionAttribute

作用:

  用于多次执行控制器方法间的参数共享。

属性:

  value:用于指定存入的属性名称

  type:用于指定存入的数据类型。

@SessionAttributes(value = {"msg"})     //将msg=flypig存入到session域对中
 1     /**
 2      * SessionAttributes注解
 3      * @return
 4      */
 5     @RequestMapping(value = "/testSessionAttributes")
 6     public String testSessionAttributes(Model model){
 7         System.out.println("testSessionAttributes。。。");
 8         //底层会存储到request域对象中
 9         model.addAttribute("msg","flypig");
10         return "success";
11
12     }
13
14     @RequestMapping(value = "/getSessionAttributes")
15     public String getSessionAttributes(ModelMap modelMap){
16         System.out.println("getSessionAttributes。。。");
17         //底层会存储到request域对象中
18         String msg = (String) modelMap.get("msg");
19         System.out.println(msg);
20         return "success";
21     }
22
23     /**
24      * 清除
25      * @param status
26      * @return
27      */
28     @RequestMapping(value = "/delSessionAttributes")
29     public String delSessionAttributes(SessionStatus status){
30         System.out.println("delSessionAttributes。。。");
31         status.setComplete();
32         return "success";
33     }

原文地址:https://www.cnblogs.com/flypig666/p/11517497.html

时间: 2024-10-14 09:55:06

springmvc:常用注解的相关文章

Spring及SpringMvc常用注解

一.Spring 常用注解 1.1  组件类的注解 @Component:一个Spring的bean上的注解,Component泛指组件,当组件不好归类的时候,我们可以使用这个注解进行标注. @Repository :持久层DAO的注解,用来标注持久层. @Service :业务逻辑层的注解,注入DAO @Controller:用于标注控制层,注入服务 <context:component-scan base-package="xx"> 这个xml配置会扫描以上注解配置的类

Spring和SpringMVC常用注解(转)

作者:IT_faquir 原文:https://blog.csdn.net/IT_faquir/article/details/78025203 个人学习所用,如有侵权,请联系删除! --------------------- 本文主要罗列Spring|SpringMVC相关注解的简介.Spring部分1.声明bean的注解 @Component 组件,没有明确的角色 @Service 在业务逻辑层使用(service层) @Repository 在数据访问层使用(dao层) @Controll

springmvc常用注解标签详解(转载)

1.@Controller 在SpringMVC 中,控制器Controller 负责处理由DispatcherServlet 分发的请求,它把用户请求的数据经过业务处理层处理之后封装成一个Model ,然后再把该Model 返回给对应的View 进行展示.在SpringMVC 中提供了一个非常简便的定义Controller 的方法,你无需继承特定的类或实现特定的接口,只需使用@Controller 标记一个类是Controller ,然后使用@RequestMapping 和@RequestP

SpringMVC 常用注解(1)

/** * @RequestMapping 除了修饰方法 还可以修饰类 * 1).类定义处:提供初步的请求映射信息,相当于WEB应用的根目录 * 2).方法定义处,提供进一步的细分映射信息,相对于类定义处的URL.若类定义处没有标注的话, * 则方法处的标记URL相当于WEB应用的根目录 * @author Hh. * */ @Controller @RequestMapping("springmvc") public class Test3 { private static fina

springmvc常用注解标签详解

在SpringMVC 中,控制器Controller 负责处理由DispatcherServlet 分发的请求,它把用户请求的数据经过业务处理层处理之后封装成一个Model ,然后再把该Model 返回给对应的View 进行展示.在SpringMVC 中提供了一个非常简便的定义Controller 的方法,你无需继承特定的类或实现特定的接口,只需使用@Controller 标记一个类是Controller ,然后使用@RequestMapping 和@RequestParam 等一些注解用以定义

springmvc 常用注解

1.@Controller 在SpringMVC 中,控制器Controller 负责处理由DispatcherServlet 分发的请求,它把用户请求的数据经过业务处理层处理之后封装成一个Model ,然后再把该Model 返回给对应的View 进行展示.在SpringMVC 中提供了一个非常简便的定义Controller 的方法,你无需继承特定的类或实现特定的接口,只需使用@Controller 标记一个类是Controller ,然后使用@RequestMapping 和@RequestP

springmvc常用注解标签详解(转载)

1.@Controller 在SpringMVC 中,控制器Controller 负责处理由DispatcherServlet 分发的请求,它把用户请求的数据经过业务处理层处理之后封装成一个Model ,然后再把该Model 返回给对应的View 进行展示.在SpringMVC 中提供了一个非常简便的定义Controller 的方法,你无需继承特定的类或实现特定的接口,只需使用@Controller 标记一个类是Controller ,然后使用@RequestMapping 和@RequestP

springmvc常用注解标签详解[转]

原文:https://www.cnblogs.com/leskang/p/5445698.html 1.@Controller 在SpringMVC 中,控制器Controller 负责处理由DispatcherServlet 分发的请求,它把用户请求的数据经过业务处理层处理之后封装成一个Model ,然后再把该Model 返回给对应的View 进行展示.在SpringMVC 中提供了一个非常简便的定义Controller 的方法,你无需继承特定的类或实现特定的接口,只需使用@Controlle

SpringMvc常用注解了解

[email protected] RequestMapping是一个用来处理请求地址映射的注解(将请求映射到对应的控制器方法中),可用于类或方法上.用于类上,表示类中的所有响应请求的方法都是以该地址作为父路径. RequestMapping请求路径映射,如果标注在某个controller的类级别上,则表明访问此类路径下的方法都要加上其配置的路径:最常用是标注在方法上,表明哪个具体的方法来接受处理某次请求.[email protected] 和RequestMapping配合使用用来代替提取路径

Springmvc常用注解

spring mvc常用的注解: 个介绍. @Controller @Controller 负责注册一个bean 到spring 上下文中,bean 的ID 默认为 类名称开头字母小写,你也可以自己指定,如下 方法一: @Controller public class TestController {}  方法二:            @Controller("tmpController") public class TestController {}  @RequestMappin