jdk8和spring3的兼容问题

用户升级旧系统,要求是jdk8,tomcat8,而原系统是jdk6和tomcat5

直接改环境后错误重重,犹如深坑望不到底。

入门的错误就是“Failed to read candidate component class”,在网上搜到的解答都是说jdk8和spring3不兼容,让降低jdk或者升级spring。

jdk降是不可能降的,那我尝试升级spring,索性选了个5,错误更是雨后春笋千姿百态,改到最后都要改产品的底层了……遂放弃。

今天不甘心,我就不信没有人遇到过我这样的困境……终于找到一个blog:

https://www.cnblogs.com/rimmy/p/13849225.html

关键内容:

  • 问题描述:spring3.* 版本不支持JDK8,启动时报错。

  • 问题原因:spring使用asm类库操作Java class文件,spring3.* 依赖的asm类库版本比较老,而JDK8之后Java class格式有变化,老版本的asm类库不能支持导致报错。

  • 解决方式和建议:

    1. 升级spring到spring4以上版本(新应用或老应用大改推荐)

      • spring4开始正式支持JDK8,实际是升级了配套的asm类库到可以支持JDK8的版本

      • 适用于新应用(新应用也强烈不建议使用spring3版本)

      • 对于老应用从spring3升级到spring4/5可能会引发很多兼容性的问题,最好是整个spring生态一起升级到新版本,但这样工作量会比较大,因此只适合老应用大改。

    2. 升级spring到spring3.2.18版本(老应用小改推荐):

      • Spring3.2.18版本是spring3系列最后一个版本

      • 保持了spring3的兼容性,同时asm类库也升级到了可以支持JDK8的版本

      • 可以比较好的平衡:改动量小,能解决spring3和jdk8的冲突问题,又不必让老应用面临升级spring4大版本的风险

    3. 降级JDK到7(老应用完全改不了的最后方案)

      • 不建议采用,JDK7过于陈旧,而且会导致后续没法使用JDK8的特性和支持这些特性的类库

      • 偏离主流技术栈(统一使用JDK8),增加开发运维的复杂度

      • 建议:只有在上面两个方法都无法使用时,不得已而为之的最后备选方案

于是 果断下载了3.2.18,好了,跑起来了……心里也松了一口气

但是tomcat5又开始报对{}的屏蔽问题Invalid character found in the request target. The valid characters are defined in RFC 7230 and RFC 3986,按着网上的方法改了各种配置xml,然而并没有效果……

继续踩坑吧……

顺便提供下载spring的地址:

https://repo.spring.io/ui/repos/tree/General/libs-release-local%2Forg%2Fspringframework%2Fspring%2F3.2.18.RELEASE%2Fspring-framework-3.2.18.RELEASE-dist.zip

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值