在SpringBoot项目的POM文件中添加spring-boot-configuration-processor的作用是什么?

写在前面

在自定义starter时,一般都会添加spring-boot-configuration-processor依赖,这是为什么呢?它的作用是什么?
答:①. 将自定义的配置类生成配置元数据,所以在引用自定义STARTER的工程的YML文件中,给自定义配置初始化时,会有属性名的提示。②. 确保在使用@ConfigurationProperties注解时,可以优雅的读取配置信息,引入该依赖后,IDEA不会出现“spring boot configuration annotation processor not configured”的错误。
本文只阐述如何将自定义的配置类生成配置元数据。

问题描述

在实际项目中发现“SPRING相关配置”在点击的时候可以跳转到对应的定义类中,而自定义的“MINIO相关配置”却无法点击。如下:spring.datasource.type可以点击,而minio.url无法点击

# SPRING相关配置
spring:
  # 数据源
  datasource:
    type: com.alibaba.druid.pool.DruidDataSource
    driver-class-name: org.postgresql.Driver
    url: jdbc:postgresql://localhost:5432/hello
    username: root
    password: 123456

# MINIO相关配置
minio:
  url: http://localhost:9000
  accessKey: root
  secretKey: 123456
  bucketName: hello-world

问题分析

之所以能够点击,是因为在spring-configuration-metadata.json文件中生成了配置的元数据,为什么自定义的未生成呢?是因为自定义的配置所在工程的pom文件中没有添加如下依赖:

 <dependency>
     <groupId>org.springframework.boot</groupId>
     <artifactId>spring-boot-configuration-processor</artifactId>
     <optional>true</optional>
 </dependency>

加入该依赖后执行:mvn clean package,可以看到预期结果,生成了spring-configuration-metadata.json,spring-boot-configuration-processor的作用是在工程编译时,根据配置类自动生成配置类的元数据信息,即META-INF目录下的spring-configuration-metadata.json文件,从而可以告诉Spring容器这个JAR包中有哪些自定义的配置,JSON文件如下:
生成的spring-configuration-metadata.json文件

官方连接:
spring-boot-configuration-processor官网连接

原文如下:
You can easily generate your own configuration metadata file from items annotated with @ConfigurationProperties by using the spring-boot-configuration-processor jar. The jar includes a Java annotation processor which is invoked as your project is compiled.

### 解决Spring Boot项目中无法导入`spring-processor` #### 检查依赖配置 对于Gradle构建工具而言,在项目的`build.gradle`文件内应确保已正确定义了`spring-boot-configuration-processor`作为可选依赖项。具体来说,应当包含如下片段: ```groovy dependencies { implementation 'org.springframework.boot:spring-boot-starter' compileOnly 'org.projectlombok:lombok' // 如果使用Lombok annotationProcessor 'org.springframework.boot:spring-boot-configuration-processor' } ``` 上述代码展示了如何通过`annotationProcessor`来引入处理器[^1]。 而对于Kotlin DSL(即`build.gradle.kts`),则需采用稍有不同的语法形式: ```kotlin dependencies { implementation("org.springframework.boot:spring-boot-starter") compileOnly("org.projectlombok:lombok") // 若适用 annotationProcessor("org.springframework.boot:spring-boot-configuration-processor") } ``` 值得注意的是,当涉及到Kotlin项目时,可能还需要额外声明编译器插件支持,比如利用`kapt`指令代替普通的`annotationProcessor`: ```groovy dependencies { kapt "org.springframework.boot:spring-boot-configuration-processor" } ``` 这一步骤有助于确保在处理注解的过程中能够正确识别并应用来自该库的功能[^2]。 #### Maven设置 如果是基于Maven的工程,则应在POM.xml里添加相应的依赖条目: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-configuration-processor</artifactId> <optional>true</optional> </dependency> ``` 这里的关键在于将`<optional>`标签设为`true`,意味着此依赖仅用于编译期而非运行时环境。 #### 常见错误排查方法 1. **版本兼容性** 需要确认所使用的Spring Boot版本与其他组件之间的匹配情况。不同版本之间可能存在API变更或是行为差异,因此建议查阅官方文档获取最新的集成指南。 2. **仓库地址验证** 确认本地或远程仓库路径无误,并且具备访问权限。有时网络连接不稳定亦可能导致下载失败等问题发生。 3. **IDE缓存清理** 开发者经常遇到由于IDE内部缓存机制引起的各类异常状况。尝试刷新项目结构、重启开发工具甚至手动删除`.m2/repository`目录下的对应包后再重新同步可能会有所帮助。 4. **多模块项目特殊考量** 对于复杂的多模块架构下,务必保证父级POM或其他共享资源文件已经包含了必要的继承关系说明以及统一管理着子模块间的公共属性设定。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

cloneme01

谢谢您的支持与鼓励!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值