Spring Boot项目中那些常用到的注解有哪些?

目录

1. 与配置相关的注解(1~3)

2. Spring MVC相关的注解(4~10)

3. 组件声明的相关注解(11~13)

4. 依赖注入相关注解(14~16)


1. 与配置相关的注解(1~3)

1. @Configuration

注解目标:类;

注解来源:Spring;

说明:声明该类是一个配置类,用于替换XML的配置方式。

2. @ComponentScan

注解目标:类;

注解来源:Spring;

说明:组件扫描,可以自动发现和装配Bean。

3. @Bean

注解目标:类;

注解来源:Spring;

说明:声明一个方法的返回值是由Spring容器管理的Bean。

2. Spring MVC相关的注解(4~10)

4. @Controller

注解目标:类;

注解来源:Spring;

说明:声明是一个控制器。再Spring项目中由控制器负责将用户发来的URl请求转发到对应的服务接口。这个注解通常与@RequestMapping注解结合使用。

5. @RequestMapping

注解目标:类,方法;

注解来源:Spring;

说明:用于将Web请求映射到控制器中的某个具体方法。(1)如果用在类上,则表示所有响应请求的方法都以该地址作为父路径;(2)如果用在方法上,则可以使用与HTTP方法对应的注解来替代使用@RequestMapping,这些注解包括@GetMapping,该注解多用于查询;@PostMapping,该注解多用于添加;@PutMapping,该注解多用于修改;@DeleteMapping,该注解多用于删除。

6. @RequestParam

注解目标:方法参数;

注解来源:Spring;

说明:将Web请求参数映射到方法的参数上。

7. @RequestBody

注解目标:方法参数;

注解来源:Spring;

说明:将Web请求体的内容映射到方法的参数上;

8. @ResponseBody

注解目标:类,方法;

注解来源:Spring;

说明:用于将方法的返回结果直接写入HTTP响应体中,一般在异步获取请求时使用,用于构建RESTFul的API。在使用@RequestMapping后,返回值通常解析为跳转路径,加上@ResponseBody后返回结果不会被解析为跳转路径,,而是直接写入HTTP响应体中。如果注解用在类上,则类中的方法会继承该注解,而不需要在方法上重复添加。

9. @PathVariable

注解目标:方法参数;

注解来源:Spring;

说明:用于接收路径参数。例如:

@RequestMapping("/book/{id}")

public BookDetail getBookById(@pathVariable int id){...}

要注意的是,方法参数中的id要与或括号中的id相同。该注解通常用于RESTFul的接口实现方法

10. @RestController

注解目标:类;

注解来源:Spring;

说明:@Controller和@ResponseBody的组合注解

3. 组件声明的相关注解(11~13)

11. @Repository

注解目标:类;

注解来源:Spring;

说明:用于在数据访问层标注DAO类。使用该注解标注的DAO类会被@ComponentScan自动发现并配置。

12:@Service

注解目标:类;

注解来源:Spring;

说明:用于业务逻辑层(服务层)标注服务类。使用该注解标注的DAO类会被@ComponentScan自动发现并配置。

13. @Component

注解目标:类;

注解来源:Spring;

说明:用于标注组件。当组件不好归类时,我们可以使用这个注解来进行标记。可以认为该注解是通用的组件标注注解。

4. 依赖注入相关注解(14~16)

14. @Autowired

注解目标:构造方法,方法,方法参数,字段;

注解来源:Spring;

说明:默认按照类型自动注入依赖的Bean,该注解可以用于对类的成员变量,方法,构造方法进行标注,未完成自动装配的工作。

15. @Resource

注解目标:类,字段,方法;

注解来源:Java;

说明:默认按名字进行自动注入依赖Bean,与@Autowried注解作用类似,但不能用于构造方法。

16. @Qualifier

注解目标:类,字段,方法,方法参数;

注解来源:Spring;

说明:当有多个相同类型的Bean时,简单来说,当一个Service层接口有多个实现类时,可以用@Qualifier("name = ?")来指定区分。该注解常与@Autowired注解一同使用。例如:

@Autowired

@Qualifier("name = demoService")

private DemoService demoService;

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值