Spring Boot 中 Lombok 注解失效的解决方案

文章目录

背景

所用 Spring Boot 版本为 4.0.3,在创建项目时,勾选了 Lombok 依赖。

在代码中给 User 实体类添加了 @Data 注解,user 对象调用自带的 getName() 方法。当项目启动时,报如下错误:

bash 复制代码
java: 找不到符号
  符号: 方法 getName()
  位置: 类型为 com.sun3285.pojo.User 的变量 user

检查 pom.xml 文件,发现确实已经引入了 Lombok 依赖:

xml 复制代码
<dependency>
    <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
    <optional>true</optional>
</dependency>

开始怀疑 Lombok 依赖是否未生效,主要是两个方向

  1. 本地问题,Lombok 依赖可能由于哪里配置不对,导致未生效;
  2. 兼容性问题,因为 Spring Boot 版本为 4.0.3,版本较高,怀疑 Lombok 依赖版本与 Spring Boot 版本不兼容,导致 Lombok 未生效。

以下是排查问题的整个过程:

排查方向一

将 Lombok 依赖配置可能出问题的地方都检查一遍:

  1. 实体类 User 是否加了 @Data 注解? 是!

  2. IDEA 是否安装了 Lombok 插件,并且插件是否启用? 是!

  3. 是否开启注解处理? 是!

  4. 在 IDEA 中打开实体类 User,通过 Ctrl + 鼠标左键 点击 @Data 注解,看是否能跳转到 Lombok 的源码? 是!

确保以上没问题后,清除 IDEA 缓存,删除项目目录下的 target 文件夹,重启 IDEA,重新启动项目,发现问题仍未解决。

于是开始排查方向二

排查方向二

首先,手动在实体类 User 中,临时手动重写 getName()、toString() 等方法,启动项目,一切顺利,无问题。

于是,怀疑 Lombok 依赖版本与 Spring Boot 版本不兼容,导致 Lombok 未生效。

接着 ,将 Spring Boot 版本降低为 3.3.5,其他保持不变,经验证,问题仍未解决。说明该问题与 Spring Boot 版本无关。

下一步,搜索网上的资料,尝试了一些方法,如:

  1. 修改 pom.xml 文件中的 Lombok 依赖:去掉 <optional> 标签,并手动指定 Lombok 依赖的版本;
  2. 修改 pom.xml 文件中的插件 plugin 配置:去掉 <build> 部分的第一个插件 maven-compiler-plugin

经验证,问题仍未解决。

最后,项目中就真的不能用 Lombok 依赖,只能手动为实体类写 getter 和 setter 方法了吗?

No!

接下来,介绍偶然发现的 Lombok 注解失效的解决方案。

解决方案

pom.xml 文件中,所有的插件 plugin 都注释掉,即以下部分

清除 IDEA 缓存,删除项目目录下的 target 文件夹,重启 IDEA,重新启动项目,一切顺利,问题解决

神奇的地方来了,下一步,将 pom.xml 文件中,上述所有的插件 plugin 都重新取消注释,即恢复原状。

清除 IDEA 缓存,删除项目目录下的 target 文件夹,重启 IDEA,重新启动项目,一切顺利,问题未复现

进一步验证

在项目编译后,在 target/classes/xxx/pojo/ 目录下找到实体类 User.class,打开,可以看到有自动生成的各种方法

如果有知道原理的伙伴,欢迎评论区留言,一起交流讨论。

相关推荐
IT_陈寒9 小时前
Redis内存飙升的锅,原来是我没搞懂这个过期策略
前端·人工智能·后端
铁皮饭盒10 小时前
26年bunjs, elysia+pg一把梭, redis都省了
前端·javascript·后端
plainGeekDev10 小时前
ButterKnife → ViewBinding
android·java·kotlin
葫芦和十三18 小时前
图解 MongoDB 19|Oplog:复制的真正载体,不是文档是操作
后端·mongodb·agent
葫芦和十三19 小时前
图解 MongoDB 20|复制延迟与 catch up:Secondary 为什么跟不上
后端·mongodb·agent
IT_陈寒1 天前
SpringBoot自动配置的坑,我的API突然就404了
前端·人工智能·后端
ServBay1 天前
为什么说 MCP 是 2026 年开发者必须掌握的黄金协议?
后端·mcp
程序员夏洛1 天前
Spring Boot 多模块项目中 IDEA 提示 Cannot resolve symbol 的一次排查记录
后端
子兮曰1 天前
OpenMontage 深度解剖:你的 AI 编程助手,其实是个视频工作室
前端·后端·ai编程