一、前言
最近又遇到一个奇葩问题。
之前项目好好的,能启动能打包;
由于这个项目没有什么需求,就什么也没有改,放了几个月。
今天要用这个项目的时候,发现打包报错:
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-***piler-plugin:3.1:***pile (default-***pile) on project my_project: ***pilation failure
[ERROR] /E:/my_project/src/main/java/***/main/MyApplication.java:[6,37] 无法访问org.mybatis.spring.annotation.MapperScan
[ERROR] 错误的类文件: E:\apache-maven-repository\org\mybatis\mybatis-spring\3.0.1\mybatis-spring-3.0.1.jar(org/mybatis/spring/annotation/MapperScan.class)
[ERROR] 类文件具有错误的版本 61.0, 应为 52.0
[ERROR] 请删除该文件或确保该文件位于正确的类路径子目录中。
启动这个项目的时候,也报这个错,无法启动。
明明几个月前是好好的,什么代码都没有改,过了几个月就不能启动不能打包了,真的奇葩。
还好最终想办法解决了这个问题,在此总结下。
二、排查过程
1.看报错信息,项目启动类MyApplication.java
里,用到了:
import org.mybatis.spring.annotation.MapperScan;
然后这句报错,说是无法访问。
2.按ctrl点进这个类查看,发现使用的是mybatis-spring-3.0.1.jar
。
3.查看maven树,发现项目里既用了mybatis-spring-3.0.1.jar
,又用了mybatis-spring-2.0.1.jar
,有冲突。
4.百度发现,报错类文件具有错误的版本 61.0, 应为 52.0
可能是某个jar包版本用的有问题。
5.从maven树中找mybatis-spring-3.0.1.jar
,找到了在pom.xml
文件中,有:
<!-- mybatis -->
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>RELEASE</version>
</dependency>
就是这里用到了mybatis-spring-3.0.1.jar
,有了冲突。
6.把上面的代码改为这样:
<!-- mybatis -->
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.0.1</version>
</dependency>
指定让它使用mybatis-spring-2.0.1.jar
。
然后再启动项目、打包项目,就没有问题了。
三、问题产生的原因
这次这个问题,主要是几个月前项目是可以启动、打包的;
这几个月内也没有改项目代码;
然后今天用的时候突然就不能启动和打包了。
本人猜测,是因为pom.xml
里之前指定的版本号是RELEASE
,而这个maven用的地址又是公司内部的,也就是从公司内部下载的依赖jar包;
几个月前,公司内部RELEASE
的包还是mybatis-spring-2.0.1.jar
,但是最近换成了mybatis-spring-3.0.1.jar
,就导致项目突然不能启动和打包了;(也没有公告说换RELEASE的jar包了,坑)
因此,只能手动指定为用2.0.1
版本的mybatis-spring-boot-starter
包,才能让项目正常启动和打包。
四、总结
1.出现类似错误如:类文件具有错误的版本 61.0, 应为 52.0
,一般是由于某个jar包版本错误导致的,需要仔细查看报错信息,选用正确版本的jar包。(可以换低版本的jar包试试,一般不用换高版本的。)
2.可以通过查看maven树的方式、找到冲突的jar包、换用正确版本的jar包。
3.如果在没有改项目代码的情况下、之前项目能用、突然出现这个错误,有可能是maven库里的jar包被更新了,就需要在自己的pom.xml
文件中手动指定使用的jar包版本号才行。