IDEA 提示: Spring Boot Configuration Annotation Processor not fount in classpath


IDEA 提示:Spring Boot Configuration Annotation Processor not fount in classpath

原因分析

您可以@ConfigurationProperties使用spring-boot-configuration-processorjar 注释的项目轻松生成自己的配置元数据文件 。jar包含一个Java注释处理器,在您编译项目时调用该处理器。要使用处理器,请包含依赖项 spring-boot-configuration-processor

解决方案
  • 使用Maven时,依赖项应声明为可选,如以下示例所示
    <dependency> 
    	<groupId>org.springframework.boot</groupId> 
    	<artifactId>spring-boot-configuration-processor</artifactId> 
    	<optional>true</optional> 
    </dependency>
    
  • 对于Gradle 4.5及更早版本,应在compileOnly配置中声明依赖项,如以下示例所示:
    dependencies {
       compileOnly "org.springframework.boot:spring-boot-configuration-processor"
    }
    
  • 使用Gradle 4.6及更高版本时,应在annotationProcessor配置中声明依赖项,如以下示例所示:
    dependencies {
       annotationProcessor "org.springframework.boot:spring-boot-configuration-processor"
    }
    
  • 如果您使用的是additional-spring-configuration-metadata.json文件, compileJava则应将任务配置为依赖于processResources任务,如以下示例所示:
    compileJava.dependsOn(processResources)
    
    此依赖关系确保在编译期间注释处理器运行时可以使用其他元数据。

处理器选择带注释的类和方法 @ConfigurationProperties。配置类中的字段值的Javadoc用于填充description属性。

[注意]
您应该只对@ConfigurationProperties字段Javadoc 使用简单文本,因为它们在添加到JSON之前不会被处理。

通过存在标准的gettersetter来发现属性,这些gettersetter具有对集合类型的特殊处理(即使只有getter存在也会检测到)。注解处理器还支持使用的@Data@Getter@Setter Lombok的注释。

[注意]
如果在项目中使用AspectJ,则需要确保注释处理器仅运行一次。有几种方法可以做到这一点。使用Maven,您可以maven-apt-plugin显式配置并仅在那里将依赖项添加到注释处理器。您还可以让AspectJ插件在maven-compiler-plugin配置中运行所有处理并禁用注释处理,如下所示:

<plugin>
	<groupId>org.apache.maven.plugins</groupId>
	<artifactId>maven-compiler-plugin</artifactId>
	<configuration>
		<proc>none</proc>
	</configuration>
</plugin>

参考地址

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

superbeyone

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值