Tomcat10 部署springMVC提示“org.springframework.web.servlet.DispatcherServlet cannot be cast to ...“错误

今天下tomcat10下部署了一个springMVC 项目,但是在跳转的时候一直提示一个错误,错误如下:
在这里插入图片描述

28-Jul-2022 15:53:50.961 信息 [RMI TCP Connection(3)-127.0.0.1] org.apache.catalina.core.ApplicationContext.log 将servlet[springmvc]标记为不可用
28-Jul-2022 15:53:50.962 严重 [RMI TCP Connection(3)-127.0.0.1] org.apache.catalina.core.StandardContext.loadOnStartup web应用程序[/springmvc_war]中的Servlet[springmvc]引发了load()异常
	java.lang.ClassCastException: class org.springframework.web.servlet.DispatcherServlet cannot be cast to class jakarta.servlet.Servlet (org.springframework.web.servlet.DispatcherServlet is in unnamed module of loader org.apache.catalina.loader.ParallelWebappClassLoader @1ff17d46; jakarta.servlet.Servlet is in unnamed module of loader java.net.URLClassLoader @3ecd23d9)
		at org.apache.catalina.core.StandardWrapper.loadServlet(StandardWrapper.java:1043)
		at org.apache.catalina.core.StandardWrapper.load(StandardWrapper.java:984)
		at org.apache.catalina.core.StandardContext.loadOnStartup(StandardContext.java:4851)
		at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5155)
		at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183)
		at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:717)
		at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:690)
		at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:743)
		at org.apache.catalina.startup.HostConfig.manageApp(HostConfig.java:1865)
		at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
		at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77)
		at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
		at java.base/java.lang.reflect.Method.invoke(Method.java:568)
		at org.apache.tomcat.util.modeler.BaseModelMBean.invoke(BaseModelMBean.java:288)
		at java.management/com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.invoke(DefaultMBeanServerInterceptor.java:814)
		at java.management/com.sun.jmx.mbeanserver.JmxMBeanServer.invoke(JmxMBeanServer.java:802)
		at org.apache.catalina.mbeans.MBeanFactory.createStandardContext(MBeanFactory.java:428)
		at org.apache.catalina.mbeans.MBeanFactory.createStandardContext(MBeanFactory.java:376)
		at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
		at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77)
		at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
		at java.base/java.lang.reflect.Method.invoke(Method.java:568)
		at org.apache.tomcat.util.modeler.BaseModelMBean.invoke(BaseModelMBean.java:288)
		at java.management/com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.invoke(DefaultMBeanServerInterceptor.java:814)
		at java.management/com.sun.jmx.mbeanserver.JmxMBeanServer.invoke(JmxMBeanServer.java:802)
		at java.management/com.sun.jmx.remote.security.MBeanServerAccessController.invoke(MBeanServerAccessController.java:472)
		at java.management.rmi/javax.management.remote.rmi.RMIConnectionImpl.doOperation(RMIConnectionImpl.java:1472)
		at java.management.rmi/javax.management.remote.rmi.RMIConnectionImpl$PrivilegedOperation.run(RMIConnectionImpl.java:1310)
		at java.base/java.security.AccessController.doPrivileged(AccessController.java:712)
		at java.management.rmi/javax.management.remote.rmi.RMIConnectionImpl.doPrivilegedOperation(RMIConnectionImpl.java:1412)
		at java.management.rmi/javax.management.remote.rmi.RMIConnectionImpl.invoke(RMIConnectionImpl.java:829)
		at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
		at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77)
		at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
		at java.base/java.lang.reflect.Method.invoke(Method.java:568)
		at java.rmi/sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:360)
		at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:200)
		at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:197)
		at java.base/java.security.AccessController.doPrivileged(AccessController.java:712)
		at java.rmi/sun.rmi.transport.Transport.serviceCall(Transport.java:196)
		at java.rmi/sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:587)
		at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(TCPTransport.java:828)
		at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.lambda$run$0(TCPTransport.java:705)
		at java.base/java.security.AccessController.doPrivileged(AccessController.java:399)
		at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport.java:704)
		at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1136)
		at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:635)
		at java.base/java.lang.Thread.run(Thread.java:833)


此错误的原因是Spring(和Spring Boot)目前只支持JavaEE而不支持JakartaEE。这意味着它只能在与JavaEE兼容的服务器上运行。而Tomcat10是JakartaEE规范的一个实现,目前不支持该规范。

唯一的解决方案是降级到tomcat9。

### 解析 Spring MVC `org.springframework.web.servlet` 类无法解析的原因 当遇到 `org.springframework.web.servlet` 下的相关类无法解析的情况时,通常是因为项目配置或依赖管理存在问题。具体原因可能涉及以下几个方面: #### 1. Maven 依赖未正确加载 如果在 `pom.xml` 文件中已经声明了必要的依赖项,但是 IDE 或构建工具未能成功下载这些依赖,则可能导致编译错误或运行时异常。 对于这种情况,建议清理本地仓库并重新安装依赖: ```shell mvn clean install -U ``` 这会强制更新所有过期的快照和发布版本[^1]。 #### 2. Web 容器初始化失败 有时即使依赖已正确引入,在启动应用服务器时仍可能出现找不到特定类的问题。特别是像 Tomcat 这样的 Servlet 容器可能会因为缺少某些配置而拒绝加载 DispatcherServlet 实例。 确保 web 应用程序描述符 (`web.xml`) 中包含了正确的 servlet 配置片段: ```xml <servlet> <servlet-name>dispatcher</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>dispatcher</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> ``` 此外还需要确认上下文参数设置无误: ```xml <context-param> <param-name>contextConfigLocation</param-name> <param-value>/WEB-INF/dispatcher-servlet.xml</param-value> </context-param> ``` 上述 XML 片段定义了一个名为 dispatcher 的 Servlet 来处理请求映射,并指定了其对应的 Spring 配置文件位置。 #### 3. 版本兼容性问题 不同版本之间的 API 变更也可能引发此类问题。例如,在整合 SSM (Spring, SpringMVC 和 MyBatis) 架构时,使用不匹配的组件版本组合容易触发 Bean 创建失败等问题。 针对此情形,推荐采用稳定版作为基础框架的选择依据;同时注意检查是否有官方文档指出的具体搭配指南可供参考。必要时调整 POM 文件内的依赖范围以适应当前环境需求[^2]。 #### 4. 路径匹配策略不当 部分情况下,默认路径匹配机制与实际 URL 结构不符也会造成类似的困扰。比如自定义拦截模式下的正则表达式编写失误就会影响路由分发逻辑。 可以尝试通过修改应用程序属性来指定更为宽松的匹配方式: ```yaml spring: mvc: pathmatch: matching-strategy: ant_path_matcher ``` 该 YAML 设置指示 Spring 使用 Ant-style pattern matcher 处理传入 HTTP 请求中的 URI 模式[^3]。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

弯_弯

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值