springmvc xml配置项目的改造执行过程

项目是开源项目 技术是spring、springmvc、springjdbc、mysql,git clone的主分支,主要开发都是提交的master分支,提供了不同版本war包下载,但是想着基于源码编译本地ide运行的想法就直接用的主分支。

IDE选则 IDEA 内置tomcat启动
首先根据项目要求建立数据库表,导入数据,修改配置文件中的mysql数据库的连接信息。

配置tomcat过程自行百度,idea中部署项目到tomcat过程,我用的tomcat是8.5版本

springmvc xml配置项目的改造执行过程_第1张图片
springmvc xml配置项目的改造执行过程_第2张图片

启动后访问程序接口报错如下图

在这里插入图片描述

根据这个报错找到springmvc配置文件中存在这个bean标签中初始化这个类,根据类名很好知道此类是用来对注解方法处理器适配器,然后查看spring-webmvc jar包下的org.springframework.web.servlet.mvc.method.annotation包下确实不存在此类,网上查得

废弃的org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter

最新使用org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter

bean标签的类替换后,重新启动tomcat容器后,报了另一个错,而且和刚才改的可能有关

在这里插入图片描述

错误是NoClassDefFoundError

NoClassDefFoundError错误的发生,是因为Java虚拟机在编译时能找到合适的类,而在运行时不能找到合适的类导致的错误。例如在运行时我们想调用某个类的方法或者访问这个类的静态成员的时候,发现这个类不可用,此时Java虚拟机就会抛出NoClassDefFoundError错误。与ClassNotFoundException的不同在于,这个错误发生只在运行时需要加载对应的类不成功,而不是编译时发生。简单总结就是,NoClassDefFoundError发生在编译时对应的类可用,而运行时在Java的classpath路径中,对应的类不可用导致的错误。

我们经常被java.lang.ClassNotFoundException和java.lang.NoClassDefFoundError这两个错误迷惑不清,尽管他们都与Java classpath有关,但是他们完全不同。NoClassDefFoundError发生在JVM在动态运行时,根据你提供的类名,在classpath中找到对应的类进行加载,但当它找不到这个类时,就发生了java.lang.NoClassDefFoundError的错误,而ClassNotFoundException是在编译的时候在classpath中找不到对应的类而发生的错误。ClassNotFoundException比NoClassDefFoundError容易解决,是因为在编译时我们就知道错误发生,并且完全是由于环境的问题导致。而如果你在J2EE的环境下工作,并且得到NoClassDefFoundError的异常,而且对应的错误的类是确实存在的,这说明这个类对于类加载器来说,可能是不可见的。

跟踪源码发现

springmvc xml配置项目的改造执行过程_第3张图片
springmvc xml配置项目的改造执行过程_第4张图片

在这里插入图片描述

springmvc xml配置项目的改造执行过程_第5张图片
到这里调用了ObjectMapper类的无参构造方法,编译可以通过,但是运行时却找不到了,所以报了NoClassDefFoundError错误。

根据前文,很明显NoClassDefFoundError的错误是因为在运行时类加载器在classpath下找不到需要加载的类,所以我们需要把对应的类加载到classpath中,或者检查为什么类在classpath中是不可用的,这个发生可能的原因如下:

① 对应的Class在java的classpath中不可用
② 你可能用jar命令运行你的程序,但类并没有在jar文件的manifest文件中的classpath属性中定义
③ 可能程序的启动脚本覆盖了原来的classpath环境变量
④ 因为NoClassDefFoundError是java.lang.LinkageError的一个子类,所以可能由于程序依赖的原生的类库不可用而导致
⑤ 检查日志文件中是否有java.lang.ExceptionInInitializerError这样的错误,NoClassDefFoundError有可能是由于静态初始化失败导致的
⑥ 如果你工作在J2EE的环境,有多个不同的类加载器,也可能导致NoClassDefFoundError

首先确定是否第一个原因,在classpath下存在此jar包
springmvc xml配置项目的改造执行过程_第6张图片
二、容器启动可能不符合此问题
后面几种原因分析可发现第六种原因最可能
回到RequestMappingHandlerAdapter类断点调试发现类加载器的委托情况也可以说父类情况,RequestMappingHandlerAdapter类加载器是application加载器的子类的子类,然后查看线程上下文加载器发现是用一个。

springmvc xml配置项目的改造执行过程_第7张图片

在这里插入图片描述

修改上下文加载器试了一下,好像没啥用,类加载器好像改不了,试了试没成功,寻求其他方式
springmvc xml配置项目的改造执行过程_第8张图片

通过网上查找资料发现
将jackson的包都替换成

	<dependency>
			<groupId>com.fasterxml.jackson.datatypegroupId>
			<artifactId>jackson-datatype-jsr310artifactId>
			<version>${version}version>
	dependency>

换了以后使用ParallelWebappClassLoader类加载器可以加载ObjectMapper

springmvc xml配置项目的改造执行过程_第9张图片

问题解决了,原因暂时没找到,以后找到了再补吧。。。

你可能感兴趣的:(springmvc xml配置项目的改造执行过程)