错误:java.lang.NoSuchMethodError: javax.servlet.ServletContext.getVirtualServerName()Ljava/lang/String;html
最近刚刚开始用SpringBoot作项目,以前项目跑得好好的,就启动不起来了,后来终于解决了这个错误,这种错误出现缘由不少吧,我这只能算一种缘由。java
直接进入正题,我遇到的致使出现这个报错的缘由:maven项目中引入了多个版本的servlet-api的jar包,项目加载时候加载错了类(加载到servlet-api包中的类),getVirtualServerName我只在SpringBoot内嵌的Tomcat的包里见到了!api
解决方案:Servlet-api 3.1.0以及以后的版本中才有getVirtualServerName,确保项目中使用的是这个版本3.1.0以及以后,或者直接排除全部Servlet-api,使用SpringBoot内嵌的tomcat.tomcat
一.SpringBoot版本是2.0.0 ,该版本下内嵌Tomcat的jar中就使用了本身的ServletContext,官方文档中标注了该方法在servlet-api 3.1.0才出现,我下载了3.1-b01也是没有该方法的! 因此意味着咱们项目若是用了Servlet-api,那版本不得低于3.1.0maven
能够查看项目的依赖,很明显发现了servlet-api 2.3 的版本,注意这可能不是你本身引入的(本身引入的解决方法就不用我说了,本身删掉dependency),别的项目引入的话,解决起来就能够参考下面的步骤。ide
我也不太了解maven类加载机制,因此说下我以为可能出现的几个问题,出现这个错误我认为就是加载的是Servlet-api 3.1.0以前的版本(和当前SpringBoot版本不匹配),项目中正好由于我把ui
axis-saaj的依赖放在了pom文件依赖最前面,而axis-saaj依赖中正好包含了servlet-api的jar,并且用的版本是2.3.0; 若是我将axis-saaj的依赖放在pom依赖最后面,容器又能够正常启动起来spa
了!插件
三.咱们就按照axis-saaj在最前面,咱们不知道哪一个依赖用了servlet-api的状况来排错! jar包那么多,依赖那么多,此次偶然,下次呢?code
POM文件中咱们右击 Diagram---》 Show Dependencies 来查看依赖图
老实说在下面这么大的网状图里找到servlet-api的jar,确实有点困难,先说找到后咋办吧,在servlet-api上右键exclude(快捷键Shift+Delete),便可排除这个版本的servlet-api;
既然找到这个这么困难,还有一种最直接的解决方案:若是项目使用的SpringBoot内嵌的Tomcat,手动添加一个Servlet-api 3.1放到Dependencies里最前面,也能够解决问题.
Maven Helper安装方式就不介绍了,IDEA settings Plugin中搜索 Maven Helper,安装、重启就可使用了. 直接上图,怎么解决这种jar冲突的问题
Maven Helper使用方式: 安装成功之后,打开POM文件,红色箭头中内容出现就是安装成功.
切换到依赖分析面板,Dependency Analyzer,而后搜索冲突的jar,在All Dependency界面就能够Exclude,很方便的找到冲突的jar,servlet-api 2.3排除掉,是否是很好很强大呢?
综上来看,最优的解决方案是在<Dependencies>下添加Servlet-api 3.1的依赖,最为直接、暴力。此外,也强烈给你们介绍了Maven Helper插件排除jar依赖的方法
<dependency> <groupId>javax.servlet</groupId> <artifactId>javax.servlet-api</artifactId> <version>3.1.0</version> <scope>provided</scope> </dependency>