记录一下 项目中遇到的 java.lang.AbstractMethodError: org.apache.tomcat.websocket.server.WsSessionListener.sessionCreated(Ljavax/servlet/http/HttpSessionEvent;)V
一、起因
起因是因为引用了
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-security</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<scope>provided </scope>
</dependency>
然后再运行代码中报错
java.lang.AbstractMethodError: org.apache.tomcat.websocket.server.WsSessionListener.sessionCreated(Ljavax/servlet/http/HttpSessionEvent;)V
java.lang.AbstractMethodError: org.apache.tomcat.websocket.server.WsSessionListener.sessionCreated(Ljavax/servlet/http/HttpSessionEvent;)V
at org.apache.catalina.session.StandardSession.tellNew(StandardSession.java:387) [tomcat-embed-core-9.0.39.jar:9.0.39]
at org.apache.catalina.session.StandardSession.setId(StandardSession.java:361) [tomcat-embed-core-9.0.39.jar:9.0.39]
at org.apache.catalina.session.StandardSession.setId(StandardSession.java:342) [tomcat-embed-core-9.0.39.jar:9.0.39]
at org.apache.catalina.session.ManagerBase.createSession(ManagerBase.java:719) [tomcat-embed-core-9.0.39.jar:9.0.39]
at org.apache.catalina.connector.Request.doGetSession(Request.java:3043) [tomcat-embed-core-9.0.39.jar:9.0.39]
at org.apache.catalina.connector.Request.getSession(Request.java:2441) [tomcat-embed-core-9.0.39.jar:9.0.39]
at org.apache.catalina.connector.RequestFacade.getSession(RequestFacade.java:908) [tomcat-embed-core-9.0.39.jar:9.0.39]
at org.apache.catalina.connector.RequestFacade.getSession(RequestFacade.java:920) [tomcat-embed-core-9.0.39.jar:9.0.39]
at javax.servlet.http.HttpServletRequestWrapper.getSession(HttpServletRequestWrapper.java:279) [javax.servlet-api-3.1.0.jar:3.1.0]
at javax.servlet.http.HttpServletRequestWrapper.getSession(HttpServletRequestWrapper.java:279) [javax.servlet-api-3.1.0.jar:3.1.0]
二、报错原因
spring boot 2.x 内置Tomcat9 ,但是我的项目中显示的指定了 javax.servlet-api 版本为3.0.1
但是Tomcat 9 使用的版本是4
三、解决方法
我的项目pom依赖中并没有 声明 javax.servlet-api 的版本号,
从项目中引用的依赖位置发现,是之前将 javax.servlet-api 3.0.1 放到了JDK的目录下,
解决方法就是在jdk中删除或者换一个jdk即可