Zend_Validate.xml 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. <sect1 id="zend.validate.introduction">
  2. <title> 简介 </title>
  3. <para>
  4. Zend_Validate 组件提供一组通用的校验器。它也提供了一个简单的校验器链机制,即在用户定义的顺序下,多个校验器可以被用于单个的数据。
  5. </para>
  6. <sect2 id="zend.validate.introduction.definition">
  7. <title> 什么是校验器(validator)? </title>
  8. <para>
  9. 校验器根据要求检查它的输入并产生一个布尔结果--是否输入被成功校验。如果输入不符合要求,校验器另外地提供信息来说明输入不符合要求。
  10. </para>
  11. <para>
  12. 例如,一个 web 应用可能要求一个用户名的长度在6 到12个字符并可能只包含数字和文字。一个校验器可以被用来确保用户名符合要求。如果一个用户名不符合一个或者全部两个要求,知道它到底不符合哪个要求将非常有用。
  13. </para>
  14. </sect2>
  15. <sect2 id="zend.validate.introduction.using">
  16. <title>校验器的基本用法</title>
  17. <para>
  18. 用这种方法定义校验为<code>Zend_Validate_Interface</code>提供了基础,它定义了两个方法,<code>isValid()</code> 和 <code>getMessages()</code>。<code>isValid()</code>方法根据提供的值来校验,当且仅当这个值通过校验条件,它返回<code>true</code>。
  19. </para>
  20. <para>
  21. 如果<code>isValid()</code>返回<code>false</code>,<code>getMessages()</code> 返回一个消息数组来解释校验失败的原因。数组键是识别校验失败原因的短字符串,数组的值是相对应的人类可读的字符串消息。键和值是独立于类的;每个校验类定义它自己的校验失败消息和独一无二的键来识别它们。每个类也有<code>const</code>定义用来为校验失败原因匹配每个识别器。
  22. </para>
  23. <note>
  24. <para>
  25. <code>getMessages()</code> 方法只为最近<code>isValid()</code>的调用返回校验失败消息。对<code>isValid()</code>每个调用清除由前一个<code>isValid()</code>调用导致的任何消息和错误,因为很可能每个<code>isValid()</code>调用用于不同的输入值。
  26. </para>
  27. </note>
  28. <para>
  29. 下面的例子示例一个e-mail地址的校验:
  30. <programlisting role="php"><![CDATA[<?php
  31. require_once 'Zend/Validate/EmailAddress.php';
  32. $validator = new Zend_Validate_EmailAddress();
  33. if ($validator->isValid($email)) {
  34. // email 有效
  35. } else {
  36. // email 无效; 打印原因
  37. foreach ($validator->getMessages() as $messageID => $message) {
  38. echo "Validation failure '$messageID': $message\n";
  39. }
  40. }
  41. ]]>
  42. </programlisting>
  43. </para>
  44. </sect2>
  45. <sect2 id="zend.validate.introduction.messages">
  46. <title> 定制消息 </title>
  47. <para>
  48. 校验类提供了一个<code>setMessage()</code>方法,你可以指定校验失败后由<code>getMessages()</code>返回的消息的格式。这个方法的第一个参数是一个包含错误信息的的字符串。你可以在字符串中包含令牌,它将被和校验器相关的数据替换。所有的校验器都支持令牌 <code>%value%</code>;这被你传递给<code>isValid()</code>的值替换。其它的令牌按情况在每个校验类中被支持。例如,<code>%max%</code>是一个被<code>Zend_Validate_LessThan</code>支持的令牌。The <code>getMessageVariables()</code>方法返回一个被校验器支持的令牌变量的数组。
  49. </para>
  50. <para>
  51. 第二个可选的参数是一个字符串,它识别是否校验失败消息模板被设置,当校验类定义了多于一个失败的原因的时候,这很有用。如果你忽略第二个参数,<code>setMessage()</code>假定你指定的消息应该被用为在校验类中声明的第一个消息模板。许多校验类只定义了一个错误消息模板,所以不需要指定哪个消息模板需要修改。
  52. </para>
  53. <para>
  54. <programlisting role="php"><![CDATA[<?php
  55. require_once 'Zend/Validate/StringLength.php';
  56. $validator = new Zend_Validate_StringLength(8);
  57. $validator->setMessage(
  58. 'The string \'%value%\' is too short; it must be at least %min% characters',
  59. Zend_Validate_StringLength::TOO_SHORT);
  60. if (!$validator->isValid('word')) {
  61. $messages = $validator->getMessages();
  62. echo $current($messages);
  63. // echoes "The string 'word' is too short; it must be at least 8 characters"
  64. }
  65. ]]>
  66. </programlisting>
  67. </para>
  68. <para>
  69. 你可以用<code>setMessages()</code>方法设置多个消息。它的参数是一个包含key/message对的数组。
  70. <programlisting role="php"><![CDATA[<?php
  71. require_once 'Zend/Validate/StringLength.php';
  72. $validator = new Zend_Validate_StringLength(8, 12);
  73. $validator->setMessages( array(
  74. Zend_Validate_StringLength::TOO_SHORT => 'The string \'%value%\' is too short',
  75. Zend_Validate_StringLength::TOO_LONG => 'The string \'%value%\' is too long'
  76. ));
  77. ]]>
  78. </programlisting>
  79. </para>
  80. <para>
  81. 如果你的应用程序要求更灵活的校验失败报告,你可以访问和消息令牌同名的属性,这个消息令牌由给定的校验类支持。<code>value</code>属性在校验器中总是有效;它是一个你指定作为<code>isValid()</code>的参数的值。其他属性按照情况在每个校验类中被支持。
  82. <programlisting role="php"><![CDATA[<?php
  83. require_once 'Zend/Validate/StringLength.php';
  84. $validator = new Zend_Validate_StringLength(8, 12);
  85. if (!validator->isValid('word')) {
  86. echo 'Word failed: '
  87. . $validator->value
  88. . '; its length is not between '
  89. . $validator->min
  90. . ' and '
  91. . $validator->max
  92. . "\n";
  93. }
  94. ]]>
  95. </programlisting>
  96. </para>
  97. </sect2>
  98. <sect2 id="zend.validate.introduction.static">
  99. <title> 使用静态 <code>is()</code> 方法 </title>
  100. <para>
  101. 如果加载一个校验类并创建这个校验器的实例不方便,你可以使用静态方法<code>Zend_Validate::is()</code>作为可选的调用风格。第一个参数是一个数据输入值,你将把它传递给<code>isValid()</code>方法。第二个参数是一个字符串,它和校验类的基本名字对应,和<code>Zend_Validate</code>名字空间相关。<code>is()</code>方法自动加载这个类,创建一个实例,并应用<code>isValid()</code>方法到数据输入。
  102. <programlisting role="php"><![CDATA[<?php
  103. require_once 'Zend/Validate.php';
  104. if (Zend_Validate::is($email, 'EmailAddress')) {
  105. // 是, email 有效
  106. }
  107. ]]>
  108. </programlisting>
  109. </para>
  110. <para>
  111. 如果校验器需要,你也可以传递一个构造器参数的数组。
  112. <programlisting role="php"><![CDATA[<?php
  113. require_once 'Zend/Validate.php';
  114. if (Zend_Validate::is($value, 'Between', array(1, 12))) {
  115. // Yes, $value is between 1 and 12
  116. }
  117. ]]>
  118. </programlisting>
  119. </para>
  120. <para>
  121. 和<code>isValid()</code>方法一样,<code>is()</code>方法返回一个布尔值。当使用静态<code>is()</code>方法时,校验失败消息不可用。
  122. </para>
  123. <para>
  124. 静态用法对于调用专用校验器可能方便,但如果为多重输入运行一个校验器,使用非静态用法更有效,创建一个校验器对象的实例并调用<code>isValid()</code>方法。
  125. </para>
  126. <para>
  127. 并且,<code>Zend_Filter_Input</code> 类允许你按需求实例化和运行多个过滤器和校验器类来处理输入数据集合,参见<xref linkend="zend.filter.input" />。
  128. </para>
  129. </sect2>
  130. </sect1>
  131. <!--
  132. vim:se ts=4 sw=4 et:
  133. -->