Modèle de conception - Modèle de filtre d'interception

Le modèle de conception de filtre d'interception est utilisé lorsque nous voulons effectuer un pré-traitement / post-traitement avec une demande ou une réponse de l'application. Les filtres sont définis et appliqués sur la demande avant de la transmettre à l'application cible réelle. Les filtres peuvent effectuer l'authentification / l'autorisation / la journalisation ou le suivi de la demande, puis transmettre les demandes aux gestionnaires correspondants. Voici les entités de ce type de modèle de conception.

  • Filter - Filtre qui effectuera certaines tâches avant ou après l'exécution de la requête par le gestionnaire de requête.

  • Filter Chain - La chaîne de filtres comporte plusieurs filtres et aide à les exécuter dans l'ordre défini sur la cible.

  • Target - L'objet cible est le gestionnaire de requêtes

  • Filter Manager - Filter Manager gère les filtres et la chaîne de filtres.

  • Client - Le client est l'objet qui envoie la demande à l'objet cible.

la mise en oeuvre

Nous allons créer un FilterChain , FilterManager , Target , Client comme divers objets représentant nos entités. AuthenticationFilter et DebugFilter représentent des filtres concrets.

InterceptingFilterDemo , notre classe de démonstration, utilisera Client pour démontrer le modèle de conception de filtre d'interception.

Étape 1

Créer une interface de filtre.

Filter.java

public interface Filter {
   public void execute(String request);
}

Étape 2

Créez des filtres en béton.

AuthenticationFilter.java

public class AuthenticationFilter implements Filter {
   public void execute(String request){
      System.out.println("Authenticating request: " + request);
   }
}

DebugFilter.java

public class DebugFilter implements Filter {
   public void execute(String request){
      System.out.println("request log: " + request);
   }
}

Étape 3

Créer une cible

Target.java

public class Target {
   public void execute(String request){
      System.out.println("Executing request: " + request);
   }
}

Étape 4

Créer une chaîne de filtres

FilterChain.java

import java.util.ArrayList;
import java.util.List;

public class FilterChain {
   private List<Filter> filters = new ArrayList<Filter>();
   private Target target;

   public void addFilter(Filter filter){
      filters.add(filter);
   }

   public void execute(String request){
      for (Filter filter : filters) {
         filter.execute(request);
      }
      target.execute(request);
   }

   public void setTarget(Target target){
      this.target = target;
   }
}

Étape 5

Créer un gestionnaire de filtres

FilterManager.java

public class FilterManager {
   FilterChain filterChain;

   public FilterManager(Target target){
      filterChain = new FilterChain();
      filterChain.setTarget(target);
   }
   public void setFilter(Filter filter){
      filterChain.addFilter(filter);
   }

   public void filterRequest(String request){
      filterChain.execute(request);
   }
}

Étape 6

Créer un client

Client.java

public class Client {
   FilterManager filterManager;

   public void setFilterManager(FilterManager filterManager){
      this.filterManager = filterManager;
   }

   public void sendRequest(String request){
      filterManager.filterRequest(request);
   }
}

Étape 7

Utilisez le client pour démontrer le modèle de conception de filtre d'interception.

InterceptingFilterDemo.java

public class InterceptingFilterDemo {
   public static void main(String[] args) {
      FilterManager filterManager = new FilterManager(new Target());
      filterManager.setFilter(new AuthenticationFilter());
      filterManager.setFilter(new DebugFilter());

      Client client = new Client();
      client.setFilterManager(filterManager);
      client.sendRequest("HOME");
   }
}

Étape 8

Vérifiez la sortie.

Authenticating request: HOME
request log: HOME
Executing request: HOME