Jersey ContainerRequestFilter not triggered


Estoy tratando de usar un ContainerRequestFilter para hacer cumplir alguna autenticación en una aplicación de Jersey basada en Tomcat. Seguí este documento . Problema: el filtro nunca se activa

La clase de filtro:

@Provider
public class AuthFilter implements ContainerRequestFilter {

    @Override
    public void filter(ContainerRequestContext requestContext)
        throws IOException {

        // MY AUTHENTICATION CODE GOES HERE

    }

La web.archivo xml :

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns="http://java.sun.com/xml/ns/javaee"
    xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
    xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
    id="debate-rest"
    version="3.0">
  <display-name>rest</display-name>
   <servlet>  
    <servlet-name>Jersey REST Service</servlet-name>  
    <servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>  
    <init-param>
        <param-name>com.sun.jersey.spi.container.ContainerRequestFilters</param-name>
        <param-value>com.hck.debate.rest.security.AuthFilter</param-value>
    </init-param>
    <init-param>  
      <param-name>jersey.config.server.provider.packages</param-name>  
      <param-value>com.hck.debate.rest.controller</param-value>  
    </init-param>  
    <init-param>  
        <param-name>com.sun.jersey.api.json.POJOMappingFeature</param-name>  
        <param-value>true</param-value>  
    </init-param>      
    <load-on-startup>1</load-on-startup>  
  </servlet>  
  <servlet-mapping>  
    <servlet-name>Jersey REST Service</servlet-name>  
    <url-pattern>/*</url-pattern>  
  </servlet-mapping>
Author: koyaga, 2013-06-25

10 answers

Bien, no entendí que el jersey.config.server.provider.packages init param necesita hacer referencia no solo a las clases de servicio (API endpoints) sino a TODAS las clases, incluidos los filtros.

Ahora funciona :

<init-param>  
  <param-name>jersey.config.server.provider.packages</param-name>  
  <param-value>com.hck.debate.rest.controller;com.hck.debate.rest.security</param-value>
</init-param>
<init-param>
    <param-name>com.sun.jersey.spi.container.ContainerRequestFilters</param-name>
    <param-value>com.hck.debate.rest.security.AuthFilter</param-value>
</init-param>
 31
Author: koyaga,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/ajaxhispano.com/template/agent.layouts/content.php on line 61
2016-06-03 18:31:49

También tuve que agregar la anotación @Provider JAX-RS a mis filtros.
Esto hace que el filtro sea detectable durante la fase de escaneo JAX-RS.

@Provider
public class MyAppFilter implements ContainerRequestFilter {
    // filter logic
}
 22
Author: uris,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/ajaxhispano.com/template/agent.layouts/content.php on line 61
2015-02-28 01:15:00

Algunas pistas:

  1. Asegúrese de que está utilizando JAX-RS versión 2.17.
  2. Asegúrate de usar las importaciones correctas en tu filtro:

    • import javax.ws.rs.container.ContainerRequestContext;
    • import javax.ws.rs.container.ContainerRequestFilter;
  3. Añadir la anotación @Provider

 5
Author: ACV,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/ajaxhispano.com/template/agent.layouts/content.php on line 61
2015-04-20 20:42:56

Los requisitos mínimos para trabajar los filtros con jersey:

  • agregue una anotación @ Provider para filtrar la clase
  • el espacio de nombres de la clase filter debe incluirse en 'jersey.config.servidor.proveedor.packages ' init-param

No se requiere ninguna otra configuración (por ejemplo, ' com.sol.Jersey.spi.contenedor.ContainerRequestFilters ' init-param or ResourceConfig)

 2
Author: crazyman,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/ajaxhispano.com/template/agent.layouts/content.php on line 61
2014-10-18 06:34:35

Tuve el mismo problema para JAX-RS 2 , jersey y la anotación a continuación lo solucionó

 @PreMatching
 2
Author: mahesh madhusudanan,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/ajaxhispano.com/template/agent.layouts/content.php on line 61
2017-04-06 09:00:01

Nos faltaba la siguiente llamada en nuestra clase de implementación ResourceConfig:

register(CorrelationIdFilter.class);
 1
Author: AshishKumar,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/ajaxhispano.com/template/agent.layouts/content.php on line 61
2018-08-13 15:17:55

En lugar de usar la anotación @Provider (que no funcionó en mi caso), puede registrar su ContainerRequestFilter manualmente con su JerseyServletFactory:

JerseyServletFactory jerseyServletFactory = new JerseyServletFactory(config);
HttpServlet myServiceServlet = jerseyServletFactory.create(myResource);

// Register your ContainerRequestFilter like this
jerseyServletFactory.addRequestFilter(new MyFilter());

httpServer.register(myServiceServlet, "/api");
httpServer.start();
 0
Author: Pierre-Luc Pineault,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/ajaxhispano.com/template/agent.layouts/content.php on line 61
2015-09-30 16:49:45

En lugar de javax.ws.rs, usé com.sol.jersey y funcionó

import com.sun.jersey.spi.container.ContainerRequestFilter import com.sun.jersey.spi.container.ContainerRequest

Los usuarios de Dropwizard necesitan hacer esto

environment.jersey().getResourceConfig()
           .getContainerRequestFilters()
           .add(filter);
 0
Author: jayantmukherji,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/ajaxhispano.com/template/agent.layouts/content.php on line 61
2016-05-07 05:43:39

Si estabas atascado como yo, ten en cuenta que TomEE 1.7.X utiliza JAX-RS 1.1, que no incluye ContainerRequestFilter.

 0
Author: Managarm,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/ajaxhispano.com/template/agent.layouts/content.php on line 61
2016-08-03 11:51:46

Para cualquiera que tenga este problema en MULE ESB. Recuerde registrar la ruta con:

<jersey:resources doc:name="REST">
   <component doc:name="rest component">
     <spring-object bean="endpoit"/>
   </component>
   <jersey:package packageName="path @Provider-s"/>
</jersey:resources >
 0
Author: HuTa,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/ajaxhispano.com/template/agent.layouts/content.php on line 61
2016-12-06 10:23:03