本文的题目其实应该是“Caused by: java.lang.NoSuchMethodException: org.springframework.boot.context.config.ConfigDataEnvironmentPostProcessor.<init>()”和“Exception in thread "main" java.lang.IllegalArgumentException: Cannot instantiate interface org.springframework.context.ApplicationListener : org.springframework.boot.cloud.CloudFoundryVcapEnvironmentPostProcessor”问题的解决。
这几天,在运行程序以后,发现竟然遇到了这个问题Caused by: java.lang.NoSuchMethodException: org.springframework.boot.context.config.ConfigDataEnvironmentPostProcessor.<init>()
很奇怪,查找了各种参考资料,包括StackOverflow,发现给出的参考资料各种各样,主要是说SpringBoot和SpringCloud版本不一致。
但是,笔者的SpringBoot和SpringCloud的版本,是专门匹配过的,显然不是这个问题。但该问题显然有启示:就是这个问题是依赖库造成的。
突然想了想,既然是依赖库有问题,就把依赖库改下即可。笔者的第一篇博客就是解决Windows动态库依赖的(加载动态库失败的原因分析_王者之路001的博客-CSDN博客_动态库加载失败),所以对这类问题深恶痛绝。
但问题还得解决,解决方法如下:在IDEA下,通过Maven视图查看依赖,并把出问题的库的版本去掉。
如下列代码,原来有版本,一直显示有问题。把version项去掉,版本正常。
<!-- https://mvnrepository.com/artifact/com.google.code.gson/gson -->
<dependency>
<groupId>com.google.code.gson</groupId>
<artifactId>gson</artifactId>
</dependency>
把pom文件改好之后,问题正常。但很奇怪,另一个问题出现了:Exception in thread "main" java.lang.IllegalArgumentException: Cannot instantiate interface org.springframework.context.ApplicationListener : org.springframework.boot.cloud.CloudFoundryVcapEnvironmentPostProcessor
该问题就简单点了,是依赖库存在Springboot库存在冲突。解决方法如下:把依赖库的Maven冲突解决。同时,导出库的JAR包时,只选择最少的文件,把依赖库去掉。
使用该方法后问题解决。