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

我有一个简单的球衣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的子类来配置应用程序,则可以通过以下方式修改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应用程序的其他可能性。

10-05 19:18