记录一下 项目中遇到的 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即可

Logo

技术共进,成长同行——讯飞AI开发者社区

更多推荐