Java 已解决:类com.sun.jersey.spi.container.servlet.ServletContainer无法强制转换为类jakarta.servlet.servlet
我实际上解决了这个问题。我将以前使用的JAR更新为1.19.1,并没有使用Apache Tomcat v10,而是恢复到v8.5版本。 我觉得在这件事上寻求帮助很愚蠢。我试图在Eclipse中用Java 已解决:类com.sun.jersey.spi.container.servlet.ServletContainer无法强制转换为类jakarta.servlet.servlet,java,eclipse,Java,Eclipse,我实际上解决了这个问题。我将以前使用的JAR更新为1.19.1,并没有使用Apache Tomcat v10,而是恢复到v8.5版本。 我觉得在这件事上寻求帮助很愚蠢。我试图在Eclipse中用java中的一个简单restful应用程序配置一个项目,无论我做什么,我都会遇到问题。下面是我得到的错误输出 我还将附上maven pom、我正在使用的代码示例和web.xml。我知道,事实上,我一定忽略了一些极其简单的事情,但我现在就是想不出它是什么 对以下发布的所有信息表示歉意: 2021年5月5日下
java
中的一个简单restful应用程序配置一个项目,无论我做什么,我都会遇到问题。下面是我得到的错误输出
我还将附上maven pom
、我正在使用的代码示例和web.xml
。我知道,事实上,我一定忽略了一些极其简单的事情,但我现在就是想不出它是什么
对以下发布的所有信息表示歉意:
2021年5月5日下午1:16:20 org.apache.catalina.core.StandardContext loadOnStartup
严重:web应用程序[/Distributed]中的Servlet[Jersey REST Service]引发load()异常
java.lang.ClassCastException:类com.sun.jersey.spi.container.servlet.ServletContainer不能强制转换为类jakarta.servlet.servlet(com.sun.jersey.spi.container.servlet.ServletContainer位于loader org.apache.catalina.loader.ParallelWebappClassLoader@545de5a4的未命名模块中;jakarta.servlet.servlet位于loader java.net.URLClassLoader@17a7cec2的未命名模块中)
位于org.apache.catalina.core.StandardWrapper.loadServlet(StandardWrapper.java:1043)
位于org.apache.catalina.core.StandardWrapper.load(StandardWrapper.java:984)
位于org.apache.catalina.core.StandardContext.loadOnStartup(StandardContext.java:4851)
位于org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5155)
位于org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183)
位于org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1384)
位于org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1374)
位于java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264)
位于org.apache.tomcat.util.threads.InlineExecutorService.execute(InlineExecutorService.java:75)
位于java.base/java.util.concurrent.AbstractExecutorService.submit(AbstractExecutorService.java:140)
位于org.apache.catalina.core.ContainerBase.startInternal(ContainerBase.java:909)
位于org.apache.catalina.core.StandardHost.startInternal(StandardHost.java:880)
位于org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183)
位于org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1384)
位于org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1374)
位于java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264)
位于org.apache.tomcat.util.threads.InlineExecutorService.execute(InlineExecutorService.java:75)
位于java.base/java.util.concurrent.AbstractExecutorService.submit(AbstractExecutorService.java:140)
位于org.apache.catalina.core.ContainerBase.startInternal(ContainerBase.java:909)
位于org.apache.catalina.core.StandardEngine.startInternal(StandardEngine.java:262)
位于org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183)
在org.apache.catalina.core.StandardService.startInternal(StandardService.java:433)
位于org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183)
位于org.apache.catalina.core.StandardServer.startInternal(StandardServer.java:930)
位于org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183)
位于org.apache.catalina.startup.catalina.start(catalina.java:795)
位于java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(本机方法)
位于java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:64)
位于java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
位于java.base/java.lang.reflect.Method.invoke(Method.java:564)
位于org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:342)
位于org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:473)
以下是pom
:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>Distributed</groupId>
<artifactId>Distributed</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>war</packaging>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.11</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>com.sun.jersey</groupId>
<artifactId>jersey-server</artifactId>
<version>1.17.1</version>
</dependency>
<dependency>
<groupId>com.sun.jersey</groupId>
<artifactId>jersey-core</artifactId>
<version>1.17.1</version>
</dependency>
<dependency>
<groupId>com.sun.jersey</groupId>
<artifactId>jersey-servlet</artifactId>
<version>1.17.1</version>
</dependency>
</dependencies>
<build>
<finalName>Distributed</finalName>
<plugins>
<plugin>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.8.1</version>
<configuration>
<release>15</release>
</configuration>
</plugin>
<plugin>
<artifactId>maven-war-plugin</artifactId>
<version>3.2.3</version>
</plugin>
</plugins>
</build>
</project>
代码
package应用程序;
导入javax.ws.rs.GET;
导入javax.ws.rs.Path;
导入javax.ws.rs.products;
导入javax.ws.rs.core.MediaType;
//普通的旧Java对象,它不作为类或实现进行扩展
//接口
//该类使用@GET注释为HTTP GET请求注册其方法。
//使用@products注释,它定义了它可以传递几种MIME类型,
//文本、XML和HTML。
//浏览器默认请求HTML MIME类型。
//设置基本URL+/hello的路径
@路径(“/hello”)
公共课你好{
//如果请求文本,则调用此方法
@得到
@生成(MediaType.TEXT\u PLAIN)
公共字符串sayplantextHello(){
返回“Hello Jersey”;
}
//如果请求XML,则调用此方法
@得到
@生成(MediaType.TEXT\u XML)
公共字符串sayXMLHello(){
返回“+”Hello Jersey“+”;
}
//如果请求HTML,则调用此方法
@得到
@生成(MediaType.TEXT\u HTML)
公共字符串sayHtmlHello(){
返回“+”+“Hello Jersey”+“
+“+”你好,泽西衫“+”+“+”;
}
}
Jersey 1.17.1早于Jakarta EE。请使用更新版本。Tomcat 10中的包名不同。
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>Distributed</groupId>
<artifactId>Distributed</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>war</packaging>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.11</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>com.sun.jersey</groupId>
<artifactId>jersey-server</artifactId>
<version>1.17.1</version>
</dependency>
<dependency>
<groupId>com.sun.jersey</groupId>
<artifactId>jersey-core</artifactId>
<version>1.17.1</version>
</dependency>
<dependency>
<groupId>com.sun.jersey</groupId>
<artifactId>jersey-servlet</artifactId>
<version>1.17.1</version>
</dependency>
</dependencies>
<build>
<finalName>Distributed</finalName>
<plugins>
<plugin>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.8.1</version>
<configuration>
<release>15</release>
</configuration>
</plugin>
<plugin>
<artifactId>maven-war-plugin</artifactId>
<version>3.2.3</version>
</plugin>
</plugins>
</build>
</project>
package app;
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;
// Plain old Java Object it does not extend as class or implements
// an interface
// The class registers its methods for the HTTP GET request using the @GET annotation.
// Using the @Produces annotation, it defines that it can deliver several MIME types,
// text, XML and HTML.
// The browser requests per default the HTML MIME type.
//Sets the path to base URL + /hello
@Path("/hello")
public class Hello {
// This method is called if TEXT_PLAIN is request
@GET
@Produces(MediaType.TEXT_PLAIN)
public String sayPlainTextHello() {
return "Hello Jersey";
}
// This method is called if XML is request
@GET
@Produces(MediaType.TEXT_XML)
public String sayXMLHello() {
return "<?xml version=\"1.0\"?>" + "<hello> Hello Jersey" + "</hello>";
}
// This method is called if HTML is request
@GET
@Produces(MediaType.TEXT_HTML)
public String sayHtmlHello() {
return "<html> " + "<title>" + "Hello Jersey" + "</title>"
+ "<body><h1>" + "Hello Jersey" + "</body></h1>" + "</html> ";
}
}