maven - 未调用 LoggingFilter - 给出 HTTP 404 - 未找到错误

标签 maven tomcat servlet-filters web.xml jersey-2.0

我正在使用 Jersey 2.3.1、Tomcat 7.0、maven。

我有一个简单的 Jersey servlet:

@Path("/myresource")
public class JerseyResource {

  @GET
  @Produces(MediaType.APPLICATION_JSON)
  public List <SecurityControlDTO> getControls() throws HibernateException {
    SecurityControlDTOManager manager = new SecurityControlDTOManager();
    return manager.getControls();
  }
}

并想添加一个 LoggingFilter。

这是我的 web.xml:

<!-- Jersey Mapping -->
    <servlet>
    <servlet-name>jersey-servlet</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.rbs.wisexec.controlservice.rest;</param-value>
    </init-param>
    <load-on-startup>1</load-on-startup>
</servlet>

    <servlet-mapping>
        <servlet-name>jersey-servlet</servlet-name>
        <url-pattern>/rest/*</url-pattern>
    </servlet-mapping>

    <filter>
        <filter-name>jersey-auth</filter-name>
        <filter-class>org.glassfish.jersey.servlet.ServletContainer</filter-class>
        <init-param>
            <param-name>javax.ws.rs.container.ContainerRequestFilter</param-name>
            <param-value>org.glassfish.jersey.filter.LoggingFilter</param-value>
        </init-param>
    </filter>
    <filter-mapping>
        <filter-name>jersey-auth</filter-name>
        <url-pattern>/rest/*</url-pattern>
        <servlet-name>jersey-servlet</servlet-name>
    </filter-mapping>

当我运行 tomcat 服务器时,服务器会启动,但当我尝试访问 URL 时,我收到“HTTP 状态 404 - 未找到”错误。我在过滤器类中有调试断点,因此我可以看到它永远不会被调用。

我尝试了各种不同的方法来在 web.xml 中配置 loggingFilter,即:

<init-param>
                <param-name>javax.ws.rs.container.ContainerRequestFilter</param-name>
                <param-value>org.glassfish.jersey.filter.LoggingFilter</param-value>
            </init-param>

在 servlet 标记内 - 这会运行服务器并显示资源,但同样不会调用过滤器。

最佳答案

如果您想通过 web.xml 而不是使用 javax.ws.rs.core.Application 的子类来配置您的应用程序,您可以通过这种方式修改您的网络描述符:

<!-- Jersey Mapping -->
<servlet>
    <servlet-name>jersey-servlet</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.rbs.wisexec.controlservice.rest;</param-value>
    </init-param>
    <init-param>
        <param-name>jersey.config.server.provider.classnames</param-name>
        <param-value>org.glassfish.jersey.filter.LoggingFilter</param-value>
    </init-param>
    <load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
    <servlet-name>jersey-servlet</servlet-name>
    <url-pattern>/rest/*</url-pattern>
</servlet-mapping>

重要的是第二个 init-param,它指出 LoggingFilter 应该添加到应用程序中的 JAX-RS 提供者列表中。参数取自ServerProperties类,您可以在其中找到此参数的描述 (ServerProperties.PROVIDER_CLASSNAMES) 以及配置 Jersey 应用程序的其他可能性。

关于maven - 未调用 LoggingFilter - 给出 HTTP 404 - 未找到错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19791632/

相关文章:

java - pdfbox 应用程序 fat jar 给出 “Cannot read JBIG2 image: jbig2-imageio is not installed” 但从 IDE 运行正常

spring - Tomcat 上的相同 Web 应用程序,每个应用程序具有不同的 log4j 配置

java - 如何清除状态 401 HttpServletResponse.SC_UNAUTHORIZED?

java - NoClassDefFoundError : org/hibernate/ejb/HibernatePersistence

eclipse - Eclipse JDK 警告的 Maven 集成

android - 坚持如何从github安装?

java - 使用 Java 中的 Logger 库登录文件时出现问题

java - 哪里可以上传Tomcat可以访问的文件?

java - 仅在某些环境中应用 servlet 过滤器

java - Jaggery 支持过滤吗?