参考:http://blog.csdn.net/wo541075754/article/details/48243403
这个问题查了很久,本来以为是代码出问题。后来找到上面的博文给与启发,其实是项目中有两个版本不同jar。通俗来说就是jar包冲突
项目加载时,类加载器加载是通过包路径去加载类的,如果有两个不同版本的jar,有可能类加载时,加载的低版本的jar包。
而代码中用的高版本的jar包的一些方法,这些方法在低版本jar中不存在,则会提示如上报错
因为查找jar冲突挺麻烦的,根本不知道是那个jar冲突
首先需要冷静分析问题,因为本人加班好几个小时心情浮躁,结果一致没找到原因,睡一觉休息好第二天上班网上找资料,马上有启发然后找到问题所在
本人处理方法:
1、本人是先找到报错的源码,这里可以看到是(MongoTemplate.java:2118)这个源码的2118行出错
根据该afterPropertiesSet()方法,发现是MongoMappingContext类型的父类里面的一个方法
然后用eclipse强大的功能,定位到源码所在的jar包
2、然后定位到源码的jar包
3、再查看该模块中是否有类似的jar包,并且查看是否版本是低一些的,然后找到A.java源码,看看是否确实没有相关的方法
如果以上三点都符合,那明显就是jar包版本冲突问题导致报错
本人是spring-data-commons-1.13.6RELEASE.jar和spring-data-commons-core-1.4.1.RELEASE.jar冲突了,删除低版本的jar依赖即可
3、除了找到冲突的jar,把有问题的jar去掉外,也可以通过maven提供的方式,排除掉有问题的jar
在eclipse中直接选中包,或者在pom视图中,右键->maven exclude maven artifact 即可
<dependency>
<groupId>org.smarabbit.dumpling</groupId>
<artifactId>dumpling-web</artifactId>
<version>${dumpling.version}</version>
<exclusions>
<exclusion>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
</exclusion>
</exclusions>
</dependency>
其中<exclusions></exclusions>就是排除掉该jar的加载
但是有可能把全部jar排除掉
也可以指定一个编译版本,右键->lock transitive dependency version,效果如下,pom会多了如下内容
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>5.0.2.RELEASE</version>
</dependency>
</dependencies>
</dependencyManagement>