在面试中,当被问及 Spring Boot 相关的注解时,很多同学可能会觉得这是日常开发中经常接触的内容,因此回答起来信心满满。然而,即使是看似简单的问题,也可能隐藏着更深层次的知识点。以下是对 Spring Boot 中常用注解的总结,希望能帮助大家更深入地理解这些注解。
1.启动类注解:
@SpringBootApplication:下面还包含很多注解,简单说一下3个比较有用的注解,也是理解自动装配的相关注解。
-
@SpringBootConfiguration:标识当前类是一个 Spring Boot 配置类。
-
@EnableAutoConfiguration:开启 Spring Boot 的自动配置功能。
-
@ComponentScan :启用组件扫描,扫描当前包及子包下的
@Component
、@Service
、@Controller
、@Repository
等注解。
2.依赖注入注解:
一、声明bean的注解:
注解 | 作用 |
---|---|
@Component | 通用组件标记 |
@Service | 标记业务层(Service 层)组件(等价于@Component)。 |
@Controller | 标记 Web 控制器组件(等价于@Component)。 |
@Repository | 标记数据访问层(DAO 层)组件(等价于@Component,Spring 会自动处理数据访问异常)。 |
@Configuration | 标记配置类(通常用于声明@Bean方法),等价于传统 Spring 的 XML 配置文件。 |
@Bean | 声明一个 Bean(标注在方法上,方法返回值会被注册到 IOC 容器)。 |
二、注入bean:
注解 | 作用 |
---|---|
@Autowired | Spring 原生注入注解(默认按类型注入,可配合@Qualifier按名称指定)。 |
@Resource | JSR-250 标准注解(默认按名称注入,无名称时按类型注入,来自javax.annotation)。 |
@Qualifier | 配合@Autowired使用,指定注入的 Bean 名称(解决同类型多 Bean 的歧义问题)。 |
@Primary | 标记同类型 Bean 中的"主选" Bean(当@Autowired遇到多 Bean 时优先选择它)。 |
@Lazy | 标记 Bean 为延迟加载(默认 IOC 启动时创建 Bean,@Lazy会在首次使用时创建)。 |
@Scope | 指定 Bean 的作用域(如singleton(默认单例)、prototype(多例)、request(HTTP 请求作用域)等)。 |
3.配置管理注解
SpringBoot 通过application.properties/yml管理配置,以下注解用于读取和绑定
注解 | 作用 |
---|---|
@Value | 读取单个配置属性(支持 SpEL 表达式),如@Value("${server.port}")。 |
@ConfigurationProperties | 批量绑定配置到 Java 对象(适用于复杂配置,如prefix="spring.datasource"绑定一组属性)。 |
@PropertySource | 加载自定义配置文件(默认加载application.properties,可用此注解加载其他文件,如@PropertySource("classpath:my-config.properties"))。 |
@EnableConfigurationProperties | 启用@ConfigurationProperties标记的类(通常配合@Configuration使用)。 |
4.web开发注解:
Spring Boot 内置 Spring MVC,以下注解用于处理 HTTP 请求、响应和参数。
一、控制器与请求映射:
注解 | 作用 |
---|---|
@RestController | RESTful 控制器(等价于@Controller + @ResponseBody,返回数据直接序列化为 JSON/XML)。 |
@Controller | 传统 MVC 控制器(需配合@ResponseBody返回数据,或返回视图)。 |
@RequestMapping | 通用请求映射(可标记类或方法,指定 URL 路径、请求方法等,如@RequestMapping("/user"))。 |
@GetMapping | @RequestMapping(method = RequestMethod.GET)的简写(处理 GET 请求)。 |
@PostMapping | 处理 POST 请求(类似@GetMapping)。 |
@PutMapping | 处理 PUT 请求。 |
@DeleteMapping | 处理 DELETE 请求。 |
二、请求参数与响应:
注解 | 作用 |
---|---|
@RequestBody | 将请求体(如 JSON)反序列化为 Java 对象(用于 POST/PUT 等带请求体的请求)。 |
@RequestParam | 读取 URL 中的查询参数(如@RequestParam("username") String name)。 |
@PathVariable | 读取 URL 路径中的占位符(如@GetMapping("/user/{id}")配合@PathVariable("id") Long userId)。 |
@ResponseBody | 将返回值序列化为 JSON/XML(通常配合@Controller使用,@RestController已内置此注解)。 |
@ResponseStatus | 设置响应状态码(如@ResponseStatus(HttpStatus.CREATED)返回 201 状态码)。 |
@CrossOrigin | 解决跨域问题(标记类或方法,指定允许的源、方法等)。 |
5.功能启动注解:
注解 | 作用 |
---|---|
@EnableAutoConfiguration | 开启自动配置(@SpringBootApplication已包含此注解)。 |
@EnableScheduling | 开启任务调度(支持@Scheduled注解)。 |
@EnableAsync | 开启异步方法支持(配合@Async使用)。 |
@EnableCaching | 开启缓存支持(配合@Cacheable、@CachePut等注解)。 |
@EnableTransactionManagement | 开启声明式事务支持(配合@Transactional使用)。 |
@EnableFeignClients | 开启 Feign 客户端(用于微服务远程调用)。 |
6.其他注解:
注解 | 作用 |
---|---|
@Transactional | 声明事务(标记方法或类,支持事务隔离级别、传播行为等配置)。 |
@Valid/@Validated | 开启参数校验(配合javax.validation约束注解,如@NotBlank、@Max)。 |
@Profile | 标记 Bean 仅在指定环境(如dev、prod)中生效(通过spring.profiles.active配置)。 |
@Import | 手动导入其他配置类或 Bean(类似 XML 中的<import>)。 |
@Aspect | 标记 AOP 切面类(配合@Pointcut、@Before等实现切面编程)。 |