web-dev-qa-db-fra.com

Jersey ContainerRequestFilter non déclenché

J'essaie d'utiliser un ContainerRequestFilter pour appliquer une authentification sur une application Jersey basée sur Tomcat. J'ai suivi ce document . Problème: le filtre n'est jamais déclenché

La classe de filtre:

@Provider
public class AuthFilter implements ContainerRequestFilter {

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

        // MY AUTHENTICATION CODE GOES HERE

    }

Le fichier web.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>
38
koyaga

D'accord, je n'ai pas compris que le jersey.config.server.provider.packages init param doit faire référence non seulement aux classes de service (points de terminaison API) mais à TOUTES les classes, y compris les filtres.

Maintenant ça marche :

<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>
34
koyaga

J'ai également dû ajouter l'annotation @ Provider JAX-RS à mes filtres.
Cela rend le filtre détectable pendant la phase de balayage JAX-RS.

@Provider
public class MyAppFilter implements ContainerRequestFilter {
    // filter logic
}
23
uris

Quelques conseils:

  1. Assurez-vous que vous utilisez JAX-RS version 2.17.
  2. Assurez-vous que vous utilisez les bonnes importations dans votre filtre:

    • import javax.ws.rs.container.ContainerRequestContext;
    • import javax.ws.rs.container.ContainerRequestFilter;
  3. Ajouter le @Provider annotation

5
ACV

L'appel ci-dessous nous manquait dans notre classe d'implémentation ResourceConfig:

register(CorrelationIdFilter.class);
2
AshishKumar

Les exigences minimales pour travailler avec des filtres en jersey:

  • ajouter une annotation @Provider à la classe de filtre
  • l'espace de noms de la classe de filtre doit être inclus dans le paramètre init de "jersey.config.server.provider.packages"

Aucun autre paramètre n'est requis (par exemple, `` com.Sun.jersey.spi.container.ContainerRequestFilters '' init-param ou ResourceConfig)

2
crazyman

J'ai eu le même problème pour JAX-RS 2, maillot et l'annotation ci-dessous l'a corrigé

 @PreMatching
2
virtuvious

Si vous étiez coincé comme moi, notez que TomEE 1.7.X utilise JAX-RS 1.1, qui n'inclut pas ContainerRequestFilter.

0
Managarm

Au lieu d'utiliser le @Provider annotation (qui ne fonctionnait pas dans mon cas), vous pouvez enregistrer votre ContainerRequestFilter manuellement avec votre 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
Pierre-Luc Pineault

Au lieu de javax.ws.rs, j'ai utilisé com.Sun.jersey et cela a fonctionné

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

Les utilisateurs de Dropwizard doivent le faire

environment.jersey().getResourceConfig()
           .getContainerRequestFilters()
           .add(filter);
0
jayantmukherji

Pour toute personne ayant ce problème dans MULE ESB. N'oubliez pas d'enregistrer le chemin avec:

<jersey:resources doc:name="REST">
   <component doc:name="rest component">
     <spring-object bean="endpoit"/>
   </component>
   <jersey:package packageName="path @Provider-s"/>
</jersey:resources >
0
HuTa