Jersey 2.x 和 Tomcat8 返回 NullPointerException,HTTP 状态 500

Jersey 2.x and Tomcat8 returning NullPointerException, HTTP status 500

我正在尝试为 android 应用程序提供简单的休息服务,但我似乎无法让它工作。我收到 404(如果我使用 servlet 2.5 和 glassfish.servletcontainer)或 Nullpointer,如果我使用 servlet 3.0,则 http 状态为 500 和此错误消息。我想不通。

我想我混合了球衣 1 和 2,但我不知道在哪里。

错误如下所示:

java.lang.NullPointerException
org.apache.catalina.loader.WebappClassLoaderBase.binaryNameToPath(WebappClassLoaderBase.java:2495)
org.apache.catalina.loader.WebappClassLoaderBase.findLoadedClass0(WebappClassLoaderBase.java:2711)
org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1184)
org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1142)
org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:490)
org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:79)
org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:616)
org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:522)
org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1095)
org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:672)
org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1500)
org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.run(NioEndpoint.java:1456)
java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
java.lang.Thread.run(Thread.java:745)

我的 web.xml 看起来像这样:

<web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
      http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
version="3.0">

<servlet>
    <servlet-name>EndPoint</servlet-name>
    <load-on-startup>1</load-on-startup>
</servlet>

<servlet-mapping>
    <servlet-name>EndPoint</servlet-name>
    <url-pattern>/REST/*</url-pattern>
</servlet-mapping>

Pom 依赖项:

<dependencies>

    <!-- Jax RS -->
    <dependency>
        <groupId>javax.ws.rs</groupId>
        <artifactId>javax.ws.rs-api</artifactId>
        <version>2.0.1</version>
    </dependency>

    <!-- Jersey 2.23.2 -->

    <dependency>
        <groupId>org.glassfish.jersey.containers</groupId>
        <artifactId>jersey-container-servlet</artifactId>
        <version>${jersey2.version}</version>
    </dependency>

    <dependency>
        <groupId>org.glassfish.jersey.core</groupId>
        <artifactId>jersey-server</artifactId>
        <version>${jersey2.version}</version>
    </dependency>

    <dependency>
        <groupId>org.glassfish.jersey.core</groupId>
        <artifactId>jersey-client</artifactId>
        <version>${jersey2.version}</version>
    </dependency>

..和简单的 java class:

@ApplicationPath("/EndPoint")
public class EndPoint extends Application{

    @GET
    @Produces(MediaType.TEXT_PLAIN)
    public Response getMsg() {
       return Response.status(200).entity("hai!").build();
    }
}

将您的端点 class 更改为:

@Path("/endpoint")
public class EndPoint{

@GET
@Produces(MediaType.TEXT_PLAIN)
public Response getMsg() {
   return Response.status(200).entity("hai!").build();
}
}

假设 EndPoint class 在 com.test 包中,因此您需要将 web.xml 配置更改为:

<servlet>
<servlet-name>Jersey REST Service</servlet-name>
<servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>     
<init-param>
    <param-name>jersey.config.server.provider.packages</param-name>
    <param-value>com.test</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>Jersey REST Service</servlet-name>
<url-pattern>/rest/*</url-pattern>
</servlet-mapping>

注意 web.xml 中的 <param-value>com.test</param-value>。它决定了 Jersey 应该在哪里搜索你的 Rest classes。