Zend_Validate-ValidatorChains.xml 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 24249 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.validate.validator_chains">
  5. <title>Kettenprüfungen</title>
  6. <para>
  7. Oft sollen mehrere Prüfungen an dem selben Wert in einer bestimmten Reihenfolge durchgeführt
  8. werden. Der folgende Code demonstriert einen Weg um das Beispiel der
  9. <link linkend="zend.validate.introduction">Einführung</link> zu Lösen, wo ein Benutzername
  10. zwischen 6 und 12 Alphanumerischen Zeichen lang sein muss:
  11. </para>
  12. <programlisting language="php"><![CDATA[
  13. // Eine Prüfkette erstellen und die Prüfungen hinzufügen
  14. $validatorChain = new Zend_Validate();
  15. $validatorChain->addValidator(
  16. new Zend_Validate_StringLength(array('min' => 6,
  17. 'max' => 12)))
  18. ->addValidator(new Zend_Validate_Alnum());
  19. // Den Benutzernamen prüfen
  20. if ($validatorChain->isValid($username)) {
  21. // Benutzername das die Prüfung bestanden
  22. } else {
  23. // Der Benutzername hat die Prüfung nicht bestanden; Gründe ausdrucken
  24. foreach ($validatorChain->getMessages() as $message) {
  25. echo "$message\n";
  26. }
  27. }
  28. ]]></programlisting>
  29. <para>
  30. Prüfungen werden in der Reihenfolge durchgeführt in der Sie
  31. <classname>Zend_Validate</classname> hinzugefügt wurden. Im obigen Beispiel wird der
  32. Benutzername zuerst geprüft um sicherzustellen das die Länge zwischen 6 und 12 Zeichen
  33. beträgt, und anschließend wird geprüft um sicherzustellen das er nur alphanumerische Zeichen
  34. enthält. Die zweite Prüfung, für alphanumerische Zeichen, wird durchgeführt egal ob die
  35. Prüfung der Länge zwischen 6 und 12 Zeichen erfolgreich war oder nicht. Das bedeutet, dass
  36. wenn beide Prüfungen fehlschlagen, <methodname>getMessages()</methodname> die
  37. Fehlermeldungen von beiden Prüfungen zurück gibt.
  38. </para>
  39. <para>
  40. In einigen Fällen macht es Sinn eine Prüfung die Kette abbrechen zu lassen wenn der
  41. Prüfprozess fehlschlägt. <classname>Zend_Validate</classname> unterstützt solche Fälle mit
  42. dem zweiten Parameter der <methodname>addValidator()</methodname> Methode. Durch Setzen von
  43. <varname>$breakChainOnFailure</varname> zu <constant>TRUE</constant> bricht die hinzugefügte
  44. Prüfung die Ausführung der Kette bei einem Fehler ab und verhindert damit die Ausführung von
  45. jeglichen anderen Prüfungen welche für diese Situation als unnötig oder nicht richtig
  46. erkannt werden. Wenn das obige Beispiel wie folgt geschrieben wird, wird die alphanumerische
  47. Prüfung nicht stattfinden wenn die Prüfung der Stringlänge fehlschlägt:
  48. </para>
  49. <programlisting language="php"><![CDATA[
  50. $validatorChain->addValidator(
  51. new Zend_Validate_StringLength(array('min' => 6,
  52. 'max' => 12)),
  53. true)
  54. ->addValidator(new Zend_Validate_Alnum());
  55. ]]></programlisting>
  56. <para>
  57. Jegliches Objekt welches das <classname>Zend_Validate_Interface</classname> enthält kann in
  58. einer Prüfkette verwendet werden.
  59. </para>
  60. </sect1>