Programmer's Reference Guide
| Standard Prüfklassen |
Kettenprüfungen
Oft sollen mehrere Prüfungen an dem selben Wert in einer bestimmten Reihenfolge durchgeführt werden. Der folgende Code demonstriert einen Weg um das Beispiel der Einführung zu Lösen, wo ein Benutzername zwischen 6 und 12 Alphanumerischen Zeichen lang sein muss:
// Eine Prüfkette erstellen und die Prüfungen hinzufügen
$validatorChain = new Zend_Validate();
$validatorChain->addValidator(new Zend_Validate_StringLength(6, 12))
->addValidator(new Zend_Validate_Alnum());
// Den Benutzernamen prüfen
if ($validatorChain->isValid($username)) {
// Benutzername das die Prüfung bestanden
} else {
// Der Benutzername hat die Prüfung nicht bestanden; Gründe ausdrucken
foreach ($validatorChain->getMessages() as $message) {
echo "$message\n";
}
}
getMessages() die Fehlermeldungen von beiden
Prüfungen zurück gibt.
In einigen Fällen macht es Sinn eine Prüfung die Kette abbrechen zu lassen wenn der
Prüfprozess fehlschlägt. Zend_Validate unterstützt solche Fälle mit
dem zweiten Parameter der addValidator() Methode. Durch Setzen von
$breakChainOnFailure zu true bricht die hinzugefügte Prüfung die
Ausführung der Kette bei einem Fehler ab und verhindert damit die Ausführung von jeglichen
anderen Prüfungen welche für diese Situation als unnötig oder nicht richtig erkannt werden.
Wenn das obige Beispiel wie folgt geschrieben wird, wird die alphanumerische Prüfung nicht
stattfinden wenn die Prüfung der Stringlänge fehlschlägt:
$validatorChain->addValidator(new Zend_Validate_StringLength(6, 12), true)
->addValidator(new Zend_Validate_Alnum());
Jegliches Objekt welches das Zend_Validate_Interface enthält kann in einer Prüfkette verwendet werden.
| Standard Prüfklassen |
