Spring3.*中ASM和JDK8版本冲突问题及解决方案
1. 问题描述
Spring3.* 中ASM版本较低,不支持对 JDK8 class文件进行操作,启动时报错。
- Tomcat报错
org.springframework.asm.MethodVisitor.visitParameter
2. 问题原因
Spring使用ASM类库操作Java class文件,Spring.* 依赖的ASM类库版本比较老,而JDK8之后Java class格式有变化,老版本的ASM类库不能支持导致报错。
3. 解决方式和建议
-
升级Spring到Spring4以上版本(新应用或老应用大改推荐)
- Spring4开始正式支持JDK8,实际是升级了配套的ASM类库到可以支持JDK8的版本
- 适用于新应用(新应用也强烈不建议使用Spring3版本)
- 对于老应用从Spring3升级到Spring4/5可能会引发很多兼容性的问题,最好是整个Spring生态一起升级到新版本,但这样工作量会比较大,因此只适合老应用大改。
-
升级Spring到Spring3.2.18版本(老应用小改推荐):
- Spring3.2.18版本是Spring3系列最后一个版本
- 保持了Spring3的兼容性,同时ASM类库也升级到了可以支持JDK8的版本
- 可以比较好的平衡:改动量小,能解决Spring3和JDK8的冲突问题,又不必让老应用面临升级Spring4大版本的风险
-
降级JDK到7(老应用完全改不了的最后方案)
- 不建议采用,JDK7过于陈旧,而且会导致后续没法使用JDK8的特性和支持这些特性的类库
- 偏离主流技术栈(统一使用JDK8),增加开发运维的复杂度
- 建议:只有在上面两个方法都无法使用时,不得已而为之的最后备选方案
参考
spring3.*和jdk8版本冲突问题及解决方案