javaEE常用注解说明

1.@Controller,@Service,@Repository,@Component,@RestController
这几个注解用于实例化class对象。分别对应于控制层,业务实现层,数据接口层,普通任意层及rest风格的控制层。并无任何实际意义。这些实例化的的类称为注册Bean

对于@Controller与@RestController
  1. @RestController注解相当于@ResponseBody + @Controller合在一起的作用
  2. 使用@RestController注解Controller,则Controller中的方法无法返回jsp页面,配置的视图解析器InternalResourceViewResolver不起作用,返回的内容就是Return 里的内容(eg:本来应该到success.jsp页面的,则其显示中文success)
  3. 如果需要返回到指定页面,则需要用 @Controller配合视图解析器InternalResourceViewResolver才行
  4. 如果需要返回JSON,XML或自定义mediaType内容到页面,则需要在对应的方法上加上@ResponseBody注解

2.@RequestMapping,@PostMapping,@GetMapping
@RequestMapping是一个用来处理请求地址映射的注解,可用于类或方法上。用于类上,表示类中的所有响应请求的方法都是以该地址作为父路径。@PostMapping,@GetMapping为@RequestMapping的进一步封装,一般用于方法路径上。表示具体的请求方式。

对于@RequestMapping的属性值,有以下几点说明。

  1. value:指定请求的实际地址,可以包含及其复杂的正则表达式;eg:@RequestMapping("/spring-web/{symbolicName:[a-z-]+}-{version:\d\.\d\.\d}.{extension:\.[a-z]}")
  2. method:指定请求的method类型, GET、POST、PUT、DELETE等;
  3. consumes:指定处理请求的提交内容类型(Content-Type),例如application/json, text/html;eg:@RequestMapping(value = "/pets", method = RequestMethod.POST, consumes="application/json")
  4. produces:指定返回的内容类型,仅当request请求头中的(Accept)类型中包含该指定类型才返回;eg:@RequestMapping(value = "/pets/{petId}", method = RequestMethod.GET, produces="application/json")
  5. params:指定request中必须包含某些参数值是,才让该方法处理。eg:@RequestMapping(value = "/pets/{petId}", method = RequestMethod.GET, params="myParam=myValue")
  6. headers:指定request中必须包含某些指定的header值,才能让该方法处理请求。eg:@RequestMapping(value = "/pets", method = RequestMethod.GET, headers="Referer=http://www.ifeng.com/")

3.@Autowired,@Value,@Resource

  1. @Autowired按照需求类型自动注入注解
  2. @Resource默认按照名称方式进行bean匹配(java注解)
  3. @Value读取properties文件中的配置值。eg:@Value("${key}")

4.@Configuration,@Bean

从Spring3.0,@Configuration用于定义配置类,可替换xml配置文件,被注解的类内部包含有一个或多个被@Bean注解的方法,这些方法将会被AnnotationConfigApplicationContext或AnnotationConfigWebApplicationContext类进行扫描,并用于构建bean定义,初始化Spring容器。相当于配置文件的。也就是具有该注解的类会在spring初始化的时候进行扫描
@Bean注解标记的对象或者实例称为使用Bean。被该注解标记后,即该实例将由spring进行管理。一般与Configuration一起使用

5.@RequestBody,@RequestParam,@PathVariable,@PathParam,@RequestHeader, @CookieValue,@SessionAttributes, @ModelAttribute
请求参数获取常用注解,其中@PathParam是jboss包下面的一个实现。

6.@SpringBootApplication

@SpringBootApplication 被 @Configuration、@EnableAutoConfiguration、@ComponentScan 注解所修饰,换言之 Springboot 提供了统一的注解来替代以上三个注解,简化程序的配置。下面解释一下各注解的功能。

  1. @EnableAutoConfiguration:启用 Spring 应用程序上下文的自动配置,试图猜测和配置您可能需要的bean。自动配置类通常采用基于你的 classpath 和已经定义的 beans 对象进行应用。
  2. @ComponentScan 注解会自动扫描指定包下的全部标有 @Component注解 的类,并注册成bean,包括 @Component 下的子注解@Service、@Repository、@Controller。
  3. @Configuration 是一个类级注释,指示对象是一个bean定义的源

7.@RefreshScope
springcloud注解,刷新配置。

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

8.@Scheduled(cron = " * * * * ?")*
spring单模块定时任务。对于多模块定时任务,请使用quartz。

9.@MapperScan
mapper注解扫描类,由spring-mybatis提供支持。

10.@RestControllerAdvice,@ControllerAdvice,@ExceptionHandler
spring前置处理器及异常处理handler

未完待续…

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值