[MANUAL] English:
[zend.git] / documentation / manual / he / module_specs / Zend_Validate-ValidatorChains.xml
blob1a5e29b33ffa1f6e0df00e6e781005cb0fe45a68
1 <sect1 id="zend.validate.validator_chains">
3     <title>שרשור פונקציות אימות</title>
5     <para>
6         לפעמים יהיה צורך בלבצע מספר בדיקות ואימותים שונים על אותו ערך בסדר מסויים. הדוגמא הבאה מציגה כיצד לפתור את הבעיה אשר מוצגת <link linkend="zend.validate.introduction">בהקדמה</link>,
7         איפה ששם המשתמש צריך להיות בין 6 ל 12 תווים ובאותיות בלבד:
9         <programlisting role="php"><![CDATA[
10 // Create a validator chain and add validators to it
11 $validatorChain = new Zend_Validate();
12 $validatorChain->addValidator(new Zend_Validate_StringLength(6, 12))
13                ->addValidator(new Zend_Validate_Alnum());
15 // Validate the username
16 if ($validatorChain->isValid($username)) {
17     // username passed validation
18 } else {
19     // username failed validation; print reasons
20     foreach ($validatorChain->getMessages() as $message) {
21         echo "$message\n";
22     }
24 ]]>
25         </programlisting>
26         הפונקציות מורצות בסדר בהם הם מתווספות ל <code>Zend_Validate</code>. בדוגמא למעלה, שם המשתמש קודם נבדדק שהוא בין 6 ל 12 תווים, ואז הוא נבדק כדי לוודאות שהוא מכיל רק אותיות ומספרים.
27         הבדיקה השנייה תמיד תרוץ, גם אם שם המשתמש הוא לא בטווח של 6 עד 12 והבדיקה הראשונה תחזיר שגיאה הבדיקה השנייה תרוץ גם כן ובמידה והיא גם תחזיר פסוק שקר גם היא תחזיר שגיאה,
28         לאחר מכן במידה ושני הבדיקות נכשלו <code>getMessages()</code> יחזיר את הודעות השגיאה משני הבדיקות.
29     </para>
31     <para>
32         בחלק מהמקרים זה הגיוני לשבור את שרשרת הבדיקות במידה ואחת מהבדיקות מחזירה פסוק שקר.
33         <code>Zend_Validate</code> תומכת בסוג פעולה זה על ידי הוספת פרמטר שני למתודת <code>addValidator()</code>.
34         על ידי הצבת ערך <code>true</code> לפרמטר השני שהוא בעצם <code>$breakChainOnFailure</code> הבדיקה שנוספה תשבור את השרשרת במידה והיא תחזיר פסוק שקר אשר יעצרו וימנעו מהרצה של פונקציות בדיקה נוספות שבאות לאחר מכן.
35         אם הדוגמא למעלה הייתה כתובה כך, אז הבדיקה של אימות שם המשתמש שהוא אותיות ומספרים בלבד לא הייתה מתבצעת במידה והבדיקה הראשונה תחזיר פסוק שקר:
37         <programlisting role="php"><![CDATA[
38 $validatorChain->addValidator(new Zend_Validate_StringLength(6, 12), true)
39         ->addValidator(new Zend_Validate_Alnum());
40 ]]>
41         </programlisting>
43     </para>
45     <para>
46         כל אובייקט אשר מיישם את <code>Zend_Validate_Interface</code> יכול להתקיים בתור שרשרת האימות.
47     </para>
49 </sect1>
50 <!--
51 vim:se ts=4 sw=4 et:
52 -->