未调用LoggingFilter - 提供HTTP 404 - Not Found错误

时间:2013-11-05 14:44:02

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

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

我有一个简单的平针织服务器:

@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标记内部 - 运行服务器并显示资源,但不再调用过滤器。

1 个答案:

答案 0 :(得分:1)

如果要通过web.xml配置应用程序而不是使用javax.ws.rs.core.Application的子类,则可以通过以下方式修改Web描述符:

<!-- 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应用程序的其他可能性。