Programmer's Reference Guide

Chapitre 18. Zend_Filter

Table des matières

18.1. Introduction
18.1.1. Qu'est-ce qu'un filtre ?
18.1.2. Utilisation basique des filtres
18.1.3. Utilisation de la méthode statique get()
18.2. Classes de filtre standards
18.2.1. Alnum
18.2.2. Alpha
18.2.3. BaseName
18.2.4. Digits
18.2.5. Dir
18.2.6. HtmlEntities
18.2.7. Int
18.2.8. Int
18.2.9. RealPath
18.2.10. StringToLower
18.2.11. StringToUpper
18.2.12. StringTrim
18.2.13. StripTags
18.3. Chaînes de filtrage
18.4. Écriture de filtres
18.5. Zend_Filter_Input
18.5.1. Déclarer des règles de filtre et de validateur
18.5.2. Créer le processeur de filtres et validateurs
18.5.3. Récupérer les champs validés/filtré, et les éventuels rapports
18.5.3.1. Demander si l'entrée est valide
18.5.3.2. Récupérer les infos des champs invalides, absents ou inconnus
18.5.3.3. Récupérer les champs valides
18.5.4. Utiliser des méta commandes pour contrôler les règles des filtres et validateurs
18.5.4.1. La méta commande FIELDS
18.5.4.2. Méta commande PRESENCE
18.5.4.3. La méta commande DEFAULT_VALUE
18.5.4.4. La méta commande ALLOW_EMPTY
18.5.4.5. La méta commande BREAK_CHAIN
18.5.4.6. La méta commande MESSAGES
18.5.4.7. Utiliser des options pour définir des méta commandes pour toutes les règles
18.5.5. Ajouter des espaces de noms comme noms de classes
18.6. Zend_Filter_Inflector
18.6.1. Opération
18.6.2. Créer des chemins vers des filtres alternatifs
18.6.3. Paramétrer la cible de l'inflecteur
18.6.4. Règles d'inflexion
18.6.4.1. Règles statiques
18.6.4.2. Règles non statiques : basées sur des filtres
18.6.4.3. Paramétrer plusieurs règles en une seule fois
18.6.5. Autres méthodes utilitaires
18.6.6. Zend_Config avec Zend_Filter_Inflector

18.1. Introduction

Le composant Zend_Filter fournit un ensemble de filtres de données usuel. Il fournit également un mécanisme simple de chaînage par lequel plusieurs filtres peuvent être appliqués à une donnée dans un ordre défini.

18.1.1. Qu'est-ce qu'un filtre ?

Généralement parlant, un filtre est utilisé pour supprimer les parties non désirées de ce qui lui est soumis tout en laissant passer la partie désirée. Dans ce cas de figure, un filtre est une opération qui restitue une partie de la donnée soumise. Ce type de filtrage est utile pour les applications Web : suppression des données soumises non conformes, élimination des espaces inutiles, etc.

Cette définition simple d'un filtre peut être étendue pour inclure des transformations généralisées aux données soumises. Une transformation communément requise dans les applications Web consiste à échapper les entités HTML. Ainsi, si un champ de formulaire est automatiquement transmis et contient des données non vérifiées (provenant par exemple d'un navigateur Web), ces données doivent être purgées de leurs entités HTML ou bien contenir uniquement des entités HTML échappées, de manière à se garantir contre des comportements non désirés et les vulnérabilités de sécurité. Afin d'assurer cette opération, les entités HTML qui sont présentes dans les données saisies doivent être soit supprimées soit échappées. Naturellement, l'approche adéquate dépend du contexte. Un filtre de suppression des entités HTML opère dans le contexte défini plus haut : une opération produisant un sous-ensemble à partir d'une donnée soumise. Cependant, un filtre échappant les entités HTML transforme la valeur entrée (par exemple, "&" sera transformé en "&". Permettre de telles choses est important pour les développeurs Web et "filtrer" dans le contexte d'utilisation de Zend_Filter consiste à réaliser des transformations sur les données soumises.

18.1.2. Utilisation basique des filtres

Avoir cette définition d'un filtre établie fournit la base pour Zend_Filter_Interface, qui nécessitent une méthode unique nommée filter() pour être implémentée par une classe de filtre.

L'exemple simple ci-dessous démontre l'utilisation d'un filtre sur les caractères esperluette (&, "ampersand" en anglais) et guillemet double (") :


$htmlEntities = new Zend_Filter_HtmlEntities();

echo $htmlEntities->filter('&'); // &
echo $htmlEntities->filter('"'); // "

18.1.3. Utilisation de la méthode statique get()

S'il est peu pratique de charger une classe de filtre donnée et créer une instance du filtre, vous pouvez utiliser la méthode statique Zend_Filter::get() comme appel alternatif. Le premier argument de cette méthode est une valeur de saisie de données, que vous passeriez à la méthode filter(). Le deuxième argument est une chaîne, qui correspond au nom de base de la classe de filtre, relativement dans l'espace de nommage Zend_Filter. La méthode get() charge automatiquement la classe, crée une instance et applique la méthode filter() à la donnée saisie.


echo Zend_Filter::get('&', 'HtmlEntities');

Vous pouvez aussi fournir un tableau de paramètres destinés au constructeur de la classe, s'ils sont nécessaires pour votre classe de filtre.


echo Zend_Filter::get('"', 'HtmlEntities', array(ENT_QUOTES));

L'utilisation statique peut être pratique pour invoquer un filtre ad hoc, mais si vous avez besoin d'exécuter un filtre pour des saisies multiples, il est plus efficace de suivre le premier exemple ci-dessus, créant une instance de l'objet de filtre et appelant sa méthode filter().

De plus, la classe Zend_Filter_Input vous permet d'instancier et d'exécuter des filtres multiples et des classes de validateurs sur demande pour traiter l'ensemble de données saisies. Voir Section 18.5, « Zend_Filter_Input ».