Zend_Validate.xml 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168
  1. <!-- EN-Revision: 12116 -->
  2. <sect1 id="zend.validate.introduction">
  3. <title>Introduction</title>
  4. <para>Le composant <classname>Zend_Validate</classname> fournit un ensemble de validateurs usuels. Il fournit également un
  5. mécanisme simple de chaînage permettant d'appliquer de multiples validateurs à une donnée dans un ordre défini par
  6. l'utilisateur.</para>
  7. <sect2 id="zend.validate.introduction.definition">
  8. <title>Qu'est-ce qu'un validateur ?</title>
  9. <para>Un validateur examine ce qui lui est soumis suivant certaines règles et retourne un résultat booléen, si
  10. la donnée est conforme aux exigences. Si ce n'est pas le cas, un validateur peut de manière optionnelle fournir
  11. des informations concernant la (ou les) règle(s) non remplie(s).</para>
  12. <para>Par exemple, une application Web peut réclamer qu'un identifiant comprennent entre six et douze caractères
  13. et ne contiennent que des caractères alphanumériques. Un validateur peut être utilisé pour s'assurer que les
  14. identifiants remplissent ces règles. Si un identifiant donné ne respecte pas l'une ou plusieurs de ces règles,
  15. il sera utile de savoir laquelle ou lesquelles en particulier.</para>
  16. </sect2>
  17. <sect2 id="zend.validate.introduction.using">
  18. <title>Utilisation basique des validateurs</title>
  19. <para>Avoir défini la validation de cette manière fournit la fondation de <classname>Zend_Validate_Interface</classname>,
  20. qui définit deux méthodes, <code>isValid()</code> et <code>getMessages()</code>. La méthode
  21. <code>isValid()</code> réalise la validation sur la valeur fournie, en retournant <code>true</code> si et
  22. seulement si la valeur respecte les critères de validation.</para>
  23. <para>Si <code>isValid()</code> retourne <code>false</code>, <code>getMessages()</code> retourne un tableau de
  24. messages expliquant la(es) raison(s) de l'échec de la validation. Les clés du tableau sont des chaînes courtes
  25. qui identifient les raisons de l'échec de la validation, et les valeurs du tableau sont les chaînes de messages
  26. humainement lisibles correspondantes. Les clés et les valeurs sont dépendantes de la classe ; chaque classe de
  27. validation définit son propre jeu de messages d'échec de validation et les clés uniques qui les identifient.
  28. Chaque classe possède aussi une définition de constantes ("<code>const</code>") qui rattachent tout
  29. identificateur à une cause d'échec de validation.</para>
  30. <para>La méthode <code>getErrors()</code> retourne un tableau d'informations courtes qui identifient la(es)
  31. raison(s) de l'échec de la validation. Ces chaînes sont fournies pour identifier les erreurs. Elles sont
  32. destinées à votre code d'application, et non à être affichées pour l'utilisateur. Ces chaînes sont dépendantes
  33. de la classe ; chaque classe de validation définit ces propres chaînes pour identifier la cause des erreurs.
  34. Chaque classe fournit de plus des constantes (<code>const</code>) qui correspondent aux identificateurs
  35. d'erreur.</para>
  36. <note>
  37. <para>La méthode <code>getMessages()</code> retourne des informations sur l'échec de validation seulement
  38. pour l'appel le plus récent de <code>isValid()</code>. Chaque appel de <code>isValid()</code> efface les
  39. messages et les erreurs déclenchées par l'appel précédent, car il est probable que chaque appel de
  40. <code>isValid()</code> est réalisé pour des données d'entrée différentes.</para>
  41. </note>
  42. <para>L'exemple suivant illustre la validation d'une adresse émail : <programlisting role="php"><![CDATA[
  43. $validator = new Zend_Validate_EmailAddress();
  44. if ($validator->isValid($email)) {
  45. // l'email est valide
  46. } else {
  47. // l'email est invalide ; affichons pourquoi
  48. foreach ($validator->getMessages() as $messageId => $message) {
  49. echo "Echec de validation '$messageId' : $message\n";
  50. }
  51. }
  52. ]]></programlisting></para>
  53. </sect2>
  54. <sect2 id="zend.validate.introduction.messages">
  55. <title>Messages personnalisés</title>
  56. <para>Les classes de validation fournissent une méthode <code>setMessage()</code> avec laquelle vous pouvez
  57. spécifier le format du message retourné par <code>getMessages()</code> dans le cas d'un échec de validation. Le
  58. premier argument de cette méthode est une chaîne contenant le message d'erreur. Vous pouvez inclure des balises
  59. dans cette chaîne qui seront substituées avec les données appropriées du validateur. La balise
  60. <code>%value%</code> est supportée par tous les validateurs ; elle est substituée par la valeur fournie à
  61. <code>isValid()</code>. D'autres balises peuvent être supportées aux cas par cas par chaque classe de
  62. validation. Par exemple, <code>%max%</code> est une balise supportée par <classname>Zend_Validate_LessThan</classname>. La
  63. méthode <code>getMessageVariables()</code> retourne un tableau des balises de variables supportées par le
  64. validateur.</para>
  65. <para>Le second paramètre optionnel est une chaîne qui identifie le modèle de message d'échec de validation qui
  66. doit être paramètré, ce qui est pratique quand une classe de validation définit plus d'une cause d'échec. Si
  67. vous omettez ce second argument, <code>setMessage()</code> considère que le message, que vous spécifiez,
  68. s'applique au premier message déclaré dans la classe de validation. La plupart des classes de validation n'ayant
  69. qu'un seul message d'erreur, il n'est pas nécessaire de spécifier distinctement dans ce cas quel message vous
  70. affectez.</para>
  71. <para><programlisting role="php"><![CDATA[
  72. $validator = new Zend_Validate_StringLength(8);
  73. $validator->setMessage(
  74. 'La chaîne \'%value%\' est trop courte ; '
  75. . 'elle doit être au moins de %min% caractères',
  76. Zend_Validate_StringLength::TOO_SHORT);
  77. if (!$validator->isValid('word')) {
  78. $messages = $validator->getMessages();
  79. echo current($messages);
  80. // affiche "La chaîne 'word' est trop courte ;
  81. // elle doit être au moins de 8 caractères"
  82. }
  83. ]]></programlisting></para>
  84. <para>Vous pouvez régler des messages multiples en utilisant la méthode <code>setMessages()</code>. Son argument
  85. dans ce cas est un tableau de paires clé/message. <programlisting role="php"><![CDATA[
  86. $validator = new Zend_Validate_StringLength(8, 12);
  87. $validator->setMessages( array(
  88. Zend_Validate_StringLength::TOO_SHORT =>
  89. 'La chaîne \'%value%\' est trop courte',
  90. Zend_Validate_StringLength::TOO_LONG =>
  91. 'La chaîne \'%value%\' est trop longue'
  92. ));
  93. ]]></programlisting></para>
  94. <para>Si votre application exige une flexibilité encore plus grande avec laquelle elle rapporte les échecs de
  95. validation, vous pouvez accéder aux propriétés par le même nom que les balises de message supportées par une
  96. classe de validation donnée. La propriété <code>value</code> est toujours accessible dans un validateur ; il
  97. s'agit de la valeur fournie comme argument à <code>isValid()</code>. D'autres propriétés peuvent être supportées
  98. au cas par cas par chaque classe de validation. <programlisting role="php"><![CDATA[
  99. $validator = new Zend_Validate_StringLength(8, 12);
  100. if (!validator->isValid('word')) {
  101. echo 'Echec du mot : '
  102. . $validator->value
  103. . ' ; sa longueur n\'est pas compris entre '
  104. . $validator->min
  105. . ' et '
  106. . $validator->max
  107. . "\n";
  108. }
  109. ]]></programlisting></para>
  110. </sect2>
  111. <sect2 id="zend.validate.introduction.static">
  112. <title>Utilisation de la méthode statique <code>is()</code></title>
  113. <para>S'il est peu pratique de charger une classe de validation donnée et créer une instance de validateur, vous
  114. pouvez utiliser la méthode statique <classname>Zend_Validate::is()</classname> comme appel alternatif. Le premier argument
  115. de cette méthode est la donnée d'entrée, que vous passeriez à la méthode <code>isValid()</code>. Le deuxième
  116. argument est une chaîne, qui correspond au nom de base de la classe de validation, relativement dans l'espace de
  117. noms <classname>Zend_Validate</classname>. La méthode <code>is()</code> charge automatiquement la classe, crée une
  118. instance et applique la méthode <code>isValid()</code> à la donnée d'entrée. <programlisting
  119. role="php"><![CDATA[
  120. if (Zend_Validate::is($email, 'EmailAddress')) {
  121. // l'email est valide
  122. }
  123. ]]></programlisting></para>
  124. <para>Vous pouvez aussi fournir un tableau de paramètres destinés au constructeur de la classe, s'ils sont
  125. nécessaires pour votre classe de validation. <programlisting role="php"><![CDATA[
  126. if (Zend_Validate::is($value, 'Between', array(1, 12))) {
  127. // $value est compris entre 1 et 12
  128. }
  129. ]]></programlisting></para>
  130. <para>La méthode <code>is()</code> retourne une valeur booléenne, la même que la méthode <code>isValid()</code>.
  131. Lors de l'utilisation de la méthode statique <code>is()</code>, les messages d'échec de validation ne sont pas
  132. disponibles.</para>
  133. <para>L'utilisation statique peut être pratique pour invoquer un validateur ad hoc, mais si vous avez besoin
  134. d'exécuter un validateur pour des données multiples, il est plus efficace de suivre le premier exemple
  135. ci-dessus, créant une instance de l'objet de validation et appelant sa méthode <code>isValid()</code>.</para>
  136. <para>De plus, la classe <classname>Zend_Filter_Input</classname> vous permet d'instancier et d'exécuter des filtres
  137. multiples et des classes de validateurs sur demande pour traiter l'ensemble de données saisies. Voir <xref
  138. linkend="zend.filter.input" />.</para>
  139. </sect2>
  140. </sect1>