Często do pewnej wartości potrzebujemy zastosować wiele weryfikatorów w określonej kolejności. Poniższy kod demonstruje sposób rozwiązania przykładu z wprowadzenia, gdzie nazwa użytkownika musi mieć długość między 6 a 12 alfanumerycznych znaków:
// Tworzymy łańcuch weryfikatorów i dodajemy do niego weryfikatory $validatorChain = new Zend_Validate(); $validatorChain->addValidator(new Zend_Validate_StringLength(6, 12)) ->addValidator(new Zend_Validate_Alnum()); // Sprawdzamy nazwę użytkownika if ($validatorChain->isValid($username)) { // nazwa użytkownika jest poprawna } else { // nazwa użytkownika nie jest poprawna; wyświetlamy komunikaty foreach ($validatorChain->getMessages() as $message) { echo "$message\n"; } }
Weryfikatory są uruchamiane w takiej kolejności, w jakiej zostały dodane
do Zend_Validate
. W powyższym przykładzie, wpierw jest
sprawdzane jest to, czy długość nazwy użytkownika mieści się miedzy 6 a
12 znaków, a następnie sprawdzane jest czy zawiera ona tylko znaki
alfanumeryczne. Druga weryfikacja, dla alfanumerycznych znaków, jest
przeprowadzana niezależnie od tego, czy pierwsza weryfikacja, dla długości
pomiędzy 6 a 12 znaków udała się. Oznacza to, że jeśli nie udadzą się
obie weryfikacje, to metoda getMessages()
zwróci wiadomości
błędów pochodzące od obu weryfikatorów.
W niektórych przypadkach sensowna może być możliwość przerwania
łańcucha weryfikatorów w przypadku, gdy proces weryfikacji nie uda się.
Zend_Validate
obsługuje takie przypadki za pomocą
ustawienia drugiego parametru w metodzie addValidator()
.
Ustawiając wartość zmiennej $breakChainOnFailure
na
true
, dodany weryfikator przerwie łańcuchowe wywoływanie
przy wystąpieniu błędu, co zapobiegnie uruchamianiu innych weryfikacji,
które w danej sytuacji zostaną uznane za bezużyteczne. Jeśli powyższy
przykład byłby napisany tak jak poniżej, wtedy weryfikacja znaków
alfanumerycznych nie byłaby przeprowadzona jeśli długość łańcucha znaków
byłaby nieodpowiednia:
$validatorChain->addValidator(new Zend_Validate_StringLength(6, 12), true) ->addValidator(new Zend_Validate_Alnum());
W łańcuchu weryfikatorów może być użyty dowolny obiekt, który implementuje
interfejs Zend_Validate_Interface
.