maven使用不当引起 Bad version number in .class file的报错

本文记录了一次因本地maven库中存在多个不同编译版本的json-1.0.jar而导致Badversionnumberin.classfile错误的排查过程。通过逐步定位和服务层代码审查,最终确定问题是由版本冲突引起,并给出了具体的解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

现象是报Bad version number in .class file的错误
实际出错是在service的一行转json的代码后面Catch JSONException的地方
由于没有提示出错的代码行,只能通过二分法在spring配置文件中逐步定位service类
然后再二分法定位报错的方法,折腾2小时。
原因最后查明:
本地的maven lib库里json-1.0.jar 有两个版本,1.0是jdk5编译的,20090211是1.6编译的;
之前的负责架构的在将ant迁到maven时,用20090211 替换了1.0,后来使用发现了问题。
项目建了三个maven module project。A+B+C,B和C是两个模块,当初更正了A的pom,但没有改BC的pom,因为BC没有用到转json,因此一直没有出问题。
A中的转json都是在action中,这次出错时是因为有人将转json写在service中。检查junit的运行环境,发现含有包20090211,估计是从BC关联引用的。
修改B、C的pom将json版本改为1.0,再检查junit的运行的source里面已经没有20090211的包。再运行,不再报版本不一致的错误。
教训:检查问题时,在A中,点JSONException,指向的是1.0版本jar包,此时未检查junit的运行参数。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值