百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 文章教程 > 正文

SpringBoot注解速查手册:涵盖107个核心注解

yund56 2025-05-03 17:01 41 浏览

引言

Spring Boot的注解体系是开发者与框架对话的“密码本”。但许多开发者仅停留在`@RestController`、`@Autowired`等基础注解的使用,对条件装配、自动配置、扩展接口等高阶注解知之甚少。本文将彻底列举SpringBoot的107个核心注解,可将本文作为 速查手册*收藏

一、IOC容器核心注解(23个)

**`@ComponentScan`** - 配置组件扫描路径
**`@Lazy`** - 延迟初始化Bean
**`@Scope`** - 设置Bean作用域(singleton/prototype等)
**`@DependsOn`** - 指定Bean初始化顺序
**`@Primary`** - 优先注入的候选Bean
**`@Lookup`** - 方法级别依赖查找
**`@AliasFor`** - 注解属性别名
**`@Role`** - 定义Bean的角色(ROLE_APPLICATION/ROLE_SUPPORT)
**`@Description`** - 添加Bean描述信息
**`@ConditionalOnJava`** - 根据Java版本注册Bean
**`@ConditionalOnResource`** - 资源文件存在时生效
**`@ConditionalOnJndi`** - JNDI存在时生效
**`@ConditionalOnCloudPlatform`** - 云平台环境检测
**`@ConditionalOnWarDeployment`** - WAR部署时生效
**`@ConditionalOnSingleCandidate`** - 当唯一候选时注册
**`@ImportSelector`** - 动态导入配置类
**`@ImportBeanDefinitionRegistrar`** - 编程式注册Bean
**`@PropertySource`** - 加载外部配置文件
**`@PropertySources`** - 多配置文件加载
**`@Repeatable`** - 可重复注解容器
**`@Profile`** - 环境隔离配置
**`@EnableLoadTimeWeaving`** - 类加载期织入
**`@EnableMBeanExport`** - 暴露JMX MBean

二、Web开发注解(18个)

**`@CookieValue`** - 获取Cookie值

**`@SessionAttribute`** - 访问Session属性

**`@SessionAttributes`** - 声明会话存储模型

**`@MatrixVariable`** - 解析矩阵变量

**`@RequestAttribute`** - 获取请求域属性

**`@InitBinder`** - 自定义数据绑定

**`@ExceptionHandler`** - 控制器异常处理

**`@ControllerAdvice`** - 全局控制器增强

**`@ModelAttribute`** - 模型数据绑定

**`@ResponseBody`** - 返回值序列化

**`@RequestMapping`** - 通用请求映射

**`@RestControllerAdvice`** - REST风格异常处理

**`@Hidden`** - Swagger隐藏API

**`@Operation`** - OpenAPI接口描述

**`@Parameter`** - 接口参数描述

**`@ApiResponse`** - 响应状态码说明

**`@Server`** - OpenAPI服务器配置

**`@Tag`** - API分组标签

三、数据访问注解(14个)

**`@EntityScan`** - JPA实体类扫描

**`@EnableJpaRepositories`** - 激活JPA仓库

**`@Query`** - 自定义查询语句

**`@Modifying`** - 标识更新操作

**`@Procedure`** - 调用存储过程

**`@Lock`** - 指定锁模式

**`@EnableTransactionManagement`** - 启用声明式事务

**`@Sql`** - 测试时执行SQL脚本

**`@SqlMergeMode`** - 控制SQL脚本合并

**`@DataJpaTest`** - JPA切片测试

**`@DynamicUpdate`** - 动态生成Update语句

**`@Access`** - JPA字段访问策略

**`@ColumnTransformer`** - 列数据转换

**`@TenantId`** - 多租户数据隔离

四、配置与属性绑定(12个)

**`@ConstructorBinding`** - 构造函数绑定配置

**`@DurationUnit`** - 时间单位配置

**`@DataSizeUnit`** - 数据大小单位配置

**`@NestedConfigurationProperty`** - 嵌套属性绑定

**`@ConfigurationPropertiesScan`** - 配置类自动扫描

**`@DeprecatedConfigurationProperty`** - 标记废弃配置项

**`@EnableConfigurationProperties`** - 启用指定配置类

**`@ConfigurationPropertiesBindHandler`** - 自定义绑定处理器

**`@AutoConfigureBefore`** - 控制自动配置顺序

**`@AutoConfigureAfter`** - 定义配置依赖顺序

**`@AutoConfigureOrder`** - 自动配置排序

**`@BootstrapWith`** - 自定义引导程序

五、安全与权限(9个)

**`@EnableWebSecurity`** - 启用Web安全配置

**`@PreAuthorize`** - 方法执行前鉴权

**`@PostAuthorize`** - 方法执行后鉴权

**`@PreFilter`** - 方法参数过滤

**`@PostFilter`** - 返回值结果过滤

**`@Secured`** - 角色权限校验

**`@EnableGlobalMethodSecurity`** - 启用方法级安全

**`@WithMockUser`** - 测试模拟用户

**`@WithAnonymousUser`** - 测试匿名用户

六、测试与验证(11个)

**`@WebMvcTest`** - MVC切片测试

**`@DataRedisTest`** - Redis测试

**`@RestClientTest`** - 客户端测试

**`@JsonTest`** - JSON序列化测试

**`@TypeExcludeFilter`** - 类型排除过滤器

**`@DynamicPropertySource`** - 动态测试属性

**`@TestConstructor`** - 测试类构造器自动注入

**`@SqlConfig`** - SQL脚本配置

**`@ParameterizedTest`** - 参数化测试

**`@RepeatedTest`** - 重复执行测试

**`@EnabledIf`** - 条件启用测试

七、高级特性(15个)

**`@EnableAsync`** - 启用异步执行

**`@EnableScheduling`** - 启用定时任务

**`@EnableCaching`** - 启用缓存机制

**`@EnableRetry`** - 启用方法重试

**`@EnableAspectJAutoProxy`** - 启用AOP代理

**`@EnableJms`** - 启用JMS消息队列

**`@EnableBatchProcessing`** - 启用批处理

**`@EnableCircuitBreaker`** - 启用熔断器

**`@EnableDiscoveryClient`** - 注册服务发现

**`@EnableFeignClients`** - 启用Feign客户端

**`@EnableConfigurationProperties`** - 批量属性绑定

**`@EnableEncryptableProperties`** - 属性加密

**`@EnableTransactionManagement`** - 事务管理

**`@EnableMBeanExport`** - JMX监控支持

**`@EnableWebFlux`** - 响应式Web支持

八、自定义扩展(5个)

**`@EnableAutoConfiguration`** - 启用自动配置

**`@AutoConfigureJson`** - 自定义JSON序列化

**`@ConditionalOnWebApplication`** - Web环境条件

**`@ConditionalOnNotWebApplication`** - 非Web环境条件

**`@ConditionalOnExpression`** - SpEL表达式条件

结语

本文系统梳理了Spring Boot框架的**107个核心注解**,覆盖以下维度:


  1. IOC容器 (23个)
  2. Web开发 (18个)
  3. 数据访问 (14个)
  4. 安全体系 (9个)
  5. 测试验证 (11个)
  6. 高级特性 (15个)
  7. 扩展机制 (5个)

建议开发者:

1. 将本文作为速查手册收藏

2. 配合Spring官方文档理解源码实现

3. 通过IDEA的`Ctrl+Click`跳转查看注解源码

4. 在开发中逐步尝试冷门注解的实战应用

**知识拓展**Spring Boot 3.0新增的`@AutoConfiguration`注解,标志着自动配置机制的进一步标准化,值得深入学习

相关推荐

豆包编程能力升级:支持HTML代码实时预览、交互

IT之家3月19日消息,IT之家从豆包官方获悉,豆包宣布AI编程功能迎来三项升级,包括HTML预览、Python运行、生成完整项目。据介绍,目前豆包支持HTML代码实时预览和交互...

1898款游戏!80、90回忆杀,重温旧梦,快速搭建中文DOS游戏服务

本内容来源于@什么值得买APP,观点仅代表作者本人|作者:羊刀仙大家好,我是羊刀仙。本期来介绍一个特别情怀向的游戏项目:chinese-dos-games。这套包含1898款经典中文DOS游戏的合集...

利用 SVG 文件内的 HTML 代码进行网络钓鱼攻击

随着时间的推移,网络钓鱼攻击的技术越来越精妙,旨在欺骗用户并规避安全措施。攻击者会使用欺骗性的URL重定向策略,例如将恶意网站地址附加到看似安全的链接后,在PDF中嵌入链接,以及发送HTML...

aardio + AI 大模型自动编写 Python 代码、网页前端代码的经验与技巧

在AI时代,老式的编程习惯完全被颠覆。原来可能要一大堆插件或工具辛苦堆出来的程序,现在只要把AI调教好了就行。aardio支持调用十几种编程语言,这很适合发挥AI大模型的优势。对于AI...

用AI制作游戏就是如此简单!

很多人不知道如何利用AI提高效率,不知道AI能帮我们做什么,其实可以让我们实现很多自己根本不懂的领域取得直观体验,比如利用DS或者豆包,输入“我想做一个简单的单机俄罗斯方块游戏”,AI会给出phtho...

不会写代码?教你用DeepSeek 三步做出小游戏

如今,借助人工智能技术,哪怕你完全看不懂代码,也能通过DeepSeek制作出属于自己的网页版大鱼吃小鱼游戏。接下来,就为大家详细介绍制作过程。第一步、向DeepSeek描述需求为何要做网页版的...

《暗黑1》被移植成网页游戏 可在浏览器上玩了

《暗黑1》,这款1996年发售的“鼠标杀手”砍杀游戏,现在可以在浏览器上玩了。国外专注暴雪游戏的Rivsoft分享了一个《暗黑1》的共享版本,该版本只包含地下城的头2个地区和三个角色职业中的一个。不...

网页代码过滤 轻松获取专辑目录

通过过滤网页代码,可以将网页上显示不全的长文件名列表完整地提取出来。我有一个含有75个视频文件的《中医诊断学》课件,文件名是以01.RMVB、02.RMVB……75.RMVB这种格式命名的。我希望能找...

IDEA 2021首个大版本发布,Java开发者感动哭了(附新亮点演示)

工欲善其事,必先利其器!就在不久之前,Java领域的开发神器IntelliJIDEA终于迎来2021年的一个重要的大版本更新:IntelliJIDEA2021.1。现如今大量的Java开发者深度...

View Source:在 iOS 上轻松查看网页源代码

在移动互联网时代,移动端的应用和web体验都尤为重要,在PC上有很多web前端工具可以选择,而在移动端貌似就少之又少了,在NEXT出现的ViewSource能帮你在iOS上查看...

当我们《寻找房祖名》,我们能找到什么?

游戏葡萄原创专稿,未经允许请勿转载柯震东,因为在九把刀电影《那些年我们追过的女孩》中饰演男主角柯景腾而走红的台湾影星,在昨天被爆出了和著名演员成龙之子房祖名吸毒被抓的丑闻,一时间相关讨论席卷社交网络。...

多用途游戏娱乐新闻网站HTML5模板

Retnews是一个响应式的HTML新闻,博客,杂志网站模板,可以使用这套前端模板简约很多设计的工作。模板有许多特性适合流行的主题商业、时尚,游戏,娱乐,生活方式、体育、科技、政治、旅行、天气、视频等...

简约好看的个人引导页HTML源码下载

源码介绍一款非常简约好看的个人引导页HTML源码,非常适合个人主页以及个人导航使用,纯HTML不需要数据库,上传服务器即可使用!...

教你如何在微信公共平台上插入小游戏(图文教程)

很多玩微信公共平台的朋友都想在公共平台上面插入几个小游戏,用来跟用户之间互动,这里花生来分享一下如何在微信公共平台上插入游戏,以及如何制作html5微信小游戏。首先是找游戏,总共有三个方法,本人比较倾...

html5重力感应剖析附源码

下面是测试html5重力感应的demohttp://bbs.qietu.com/html/zhongli/http://www.qietu.com/html/f2/qqqianbao/demo2是切图...