Zend_Validate-Set.xml 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 18298 -->
  4. <sect1 id="zend.validate.set" xmlns:xi="http://www.w3.org/2001/XInclude">
  5. <title>標準のバリデーションクラス群</title>
  6. <para>
  7. Zend Framework には、すぐに使える標準のバリデーションクラス群が同梱されています。
  8. </para>
  9. <sect2 id="zend.validate.set.alnum">
  10. <title>Alnum</title>
  11. <para>
  12. <code>$value</code> がアルファベットおよび数字のみで構成されているときにのみ <constant>TRUE</constant> を返します。
  13. このバリデータでは、オプションとして空白文字を認めることもできます。
  14. </para>
  15. <note>
  16. <para>
  17. アルファベットとは各言語で単語を構成する文字を意味します。
  18. ただし、以下の言語では英語のアルファベットをアルファベットとして扱います:中国語、日本語、韓国語。
  19. 言語は<classname>Zend_Locale</classname>で指定されます。
  20. </para>
  21. </note>
  22. </sect2>
  23. <sect2 id="zend.validate.set.alpha">
  24. <title>Alpha</title>
  25. <para>
  26. <code>$value</code> がアルファベットのみで構成されているときにのみ <constant>TRUE</constant> を返します。
  27. このバリデータでは、オプションとして空白文字を認めることもできます。
  28. </para>
  29. </sect2>
  30. <sect2 id="zend.validate.set.barcode">
  31. <title>Barcode</title>
  32. <para>
  33. このバリデータのインスタンスを作成する際には、検証したいバーコードの形式を指定します。
  34. 現在サポートしているバーコード形式は "<code>UPC-A</code>" (Universal Product Code) と
  35. "<code>EAN-13</code>" (European Article Number) です。
  36. <methodname>isValid()</methodname> メソッドは、
  37. 指定した型のバーコードの検証アルゴリズムで入力が検証できた場合に
  38. true を返します。このバリデータに入力を渡す前に、
  39. 数字の 0 から 9 まで (0-9) 以外の文字はすべて取り除いておかなければなりません。
  40. </para>
  41. </sect2>
  42. <sect2 id="zend.validate.set.between">
  43. <title>Between</title>
  44. <para>
  45. <code>$value</code> が最小値と最大値の間にある場合にのみ <constant>TRUE</constant> を返します。
  46. デフォルトでは、両端の値も含めて比較します
  47. (<code>$value</code> が境界値と等しくてもかまいません)
  48. が、strict オプションを変更して、<code>$value</code> が最小値より大きくて最大値より小さい
  49. (最小値と最大値は含まない) とすることもできます。
  50. </para>
  51. </sect2>
  52. <xi:include href="Zend_Validate-Callback.xml">
  53. <xi:fallback><xi:include href="../../en/module_specs/Zend_Validate-Callback.xml" /></xi:fallback>
  54. </xi:include>
  55. <sect2 id="zend.validate.set.ccnum">
  56. <title>Ccnum</title>
  57. <para>
  58. <code>$value</code> が Luhn アルゴリズム (10 で割ったあまりのチェックサム)
  59. を満たすクレジットカード番号である場合にのみ <constant>TRUE</constant> を返します。
  60. </para>
  61. </sect2>
  62. <sect2 id="zend.validate.set.date">
  63. <title>Date</title>
  64. <para>
  65. <code>$value</code> が <code>YYYY-MM-DD</code> 形式の日付である場合にのみ
  66. <constant>TRUE</constant> を返します。オプションの <code>locale</code>
  67. を設定すると、そのロケールに応じた検証を行います。
  68. オプションの <code>format</code> を設定すると、
  69. そのフォーマットを使用して検証を行います。オプションパラメータの詳細は
  70. <link linkend="zend.date.others.comparison.table">Zend_Date::isDate()</link>
  71. を参照ください。
  72. </para>
  73. </sect2>
  74. <xi:include href="Zend_Validate-Db.xml" />
  75. <sect2 id="zend.validate.set.digits">
  76. <title>Digits</title>
  77. <para>
  78. <code>$value</code> が数字のみで構成されている場合にのみ <constant>TRUE</constant> を返します。
  79. </para>
  80. </sect2>
  81. <xi:include href="Zend_Validate-EmailAddress.xml" />
  82. <sect2 id="zend.validate.set.float">
  83. <title>Float</title>
  84. <para>
  85. <code>$value</code> が浮動小数点値である場合にのみ <constant>TRUE</constant> を返します。
  86. Zend Framework 1.8 以降では、このバリデータは
  87. ブラウザや環境変数あるいはアプリケーションで設定されたロケールを考慮するようになります。
  88. もちろん、アクセサ get/setLocale を使用して、
  89. バリデータのインスタンスを作成する際に使用するロケールを変更することもできます。
  90. </para>
  91. </sect2>
  92. <sect2 id="zend.validate.set.greater_than">
  93. <title>GreaterThan</title>
  94. <para>
  95. <code>$value</code> が最小値よりも大きい場合にのみ <constant>TRUE</constant> を返します。
  96. </para>
  97. </sect2>
  98. <sect2 id="zend.validate.set.hex">
  99. <title>Hex</title>
  100. <para>
  101. <code>$value</code> が16進文字のみで構成されている場合にのみ <constant>TRUE</constant> を返します。
  102. </para>
  103. </sect2>
  104. <xi:include href="Zend_Validate-Hostname.xml" />
  105. <sect2 id="zend.validate.set.iban">
  106. <title>Iban</title>
  107. <para>
  108. <code>$value</code> が正しい IBAN
  109. (International Bank Account Number) を含む場合にのみ <constant>TRUE</constant> を返します。
  110. IBAN 番号の検証は、使用している国に対して行い、チェックサムを使用します。
  111. </para>
  112. <para>
  113. IBAN 番号の検証方法は 2 通りあります。最初の方法では、国を表すロケールを指定します。
  114. その国に対して、指定した IBAN 番号の検証を行います。
  115. </para>
  116. <programlisting language="php"><![CDATA[
  117. $validator = new Zend_Validate_Iban('de_AT');
  118. $iban = 'AT611904300234573201';
  119. if ($validator->isValid($iban)) {
  120. // IBAN は有効なようです
  121. } else {
  122. // IBAN は無効です
  123. foreach ($validator->getMessages() as $message) {
  124. echo "$message\n";
  125. }
  126. }
  127. ]]></programlisting>
  128. <para>
  129. これは、IBAN 番号をひとつの国に対して検証したい場合に使用します。
  130. もっとシンプルな方法としては、この例のようにロケールを指定しないものもあります。
  131. </para>
  132. <programlisting language="php"><![CDATA[
  133. $validator = new Zend_Validate_Iban();
  134. $iban = 'AT611904300234573201';
  135. if ($validator->isValid($iban)) {
  136. // IBAN は有効なようです
  137. } else {
  138. // IBAN は無効です
  139. }
  140. ]]></programlisting>
  141. <para>
  142. しかしこれには大きな問題がひとつあります。
  143. たとえばフランスならフランスなど 1 か国だけの IBAN 番号を許可したいときに、
  144. 他の国の IBAN 番号も有効となってしまいます。
  145. したがって、特定の国の IBAN 番号を検証したい場合はロケールを指定しなければなりません。
  146. 国にこだわらずすべての IBAN 番号を許可したい場合は、
  147. ロケールを省略してシンプルに書くことができます。
  148. </para>
  149. </sect2>
  150. <sect2 id="zend.validate.set.identical">
  151. <title>Identical</title>
  152. <para>
  153. 指定したトークンが <code>$value</code> と一致する場合にのみ <constant>TRUE</constant>
  154. を返します。このバリデータは任意の型を処理することができます。
  155. </para>
  156. <para>
  157. 検証したいトークンは初期化時にパラメータとして設定することもできますし、
  158. <methodname>setToken()</methodname> メソッドで設定することもできます。
  159. </para>
  160. <programlisting language="php"><![CDATA[
  161. // 初期化時のトークン設定
  162. $validator = new Zend_Validate_Identical(array('one' => 'two'));
  163. if ($validator->isValid(array('one' => 'two'))) { // 有効なトークンです
  164. // 何かをします
  165. }
  166. // setToken() によるトークン設定
  167. $validator->setToken(true);
  168. if ($validator->isValid(1)) { // 有効なトークンです
  169. // 何かをします
  170. }
  171. ]]></programlisting>
  172. </sect2>
  173. <xi:include href="Zend_Validate-InArray.xml" />
  174. <sect2 id="zend.validate.set.int">
  175. <title>Int</title>
  176. <para>
  177. <code>$value</code> が整数値である場合にのみ <constant>TRUE</constant> を返します。
  178. Zend Framework 1.8 以降では、このバリデータは
  179. ブラウザや環境変数あるいはアプリケーションで設定されたロケールを考慮するようになります。
  180. もちろん、アクセサ get/setLocale を使用して、
  181. バリデータのインスタンスを作成する際に使用するロケールを変更することもできます。
  182. </para>
  183. </sect2>
  184. <sect2 id="zend.validate.set.ip">
  185. <title>Ip</title>
  186. <para>
  187. <code>$value</code> が妥当な形式の IP アドレスである場合にのみ <constant>TRUE</constant> を返します。
  188. </para>
  189. </sect2>
  190. <sect2 id="zend.validate.set.less_than">
  191. <title>LessThan</title>
  192. <para>
  193. <code>$value</code> が最大値よりも小さい場合にのみ <constant>TRUE</constant> を返します。
  194. </para>
  195. </sect2>
  196. <sect2 id="zend.validate.set.not_empty">
  197. <title>NotEmpty</title>
  198. <para>
  199. <code>$value</code> が空の値でない場合にのみ <constant>TRUE</constant> を返します。
  200. </para>
  201. </sect2>
  202. <xi:include href="Zend_Validate-PostCode.xml">
  203. <xi:fallback><xi:include href="../../en/module_specs/Zend_Validate-PostCode.xml" /></xi:fallback>
  204. </xi:include>
  205. <sect2 id="zend.validate.set.regex">
  206. <title>Regex</title>
  207. <para>
  208. <code>$value</code> が正規表現パターンにマッチする場合にのみ <constant>TRUE</constant> を返します。
  209. </para>
  210. </sect2>
  211. <xi:include href="Zend_Validate-Sitemap.xml" />
  212. <sect2 id="zend.validate.set.string_length">
  213. <title>StringLength</title>
  214. <para>
  215. 文字列 <code>$value</code> の長さが最小値以上、
  216. かつ最大値以下 (最大値が <constant>NULL</constant> 以外のとき)
  217. の場合にのみ <constant>TRUE</constant> を返します。
  218. <methodname>setMin()</methodname>
  219. で最大値より大きい値を指定したり <methodname>setMax()</methodname>
  220. で最小値より小さい値を設定したりした場合に例外をスローします。
  221. このクラスは UTF-8 のほかに
  222. <ulink url="http://www.php.net/manual/ja/ref.iconv.php#iconv.configuration"><code>iconv.internal_encoding</code></ulink>
  223. にもとづいたその他の文字エンコーディングもサポートします。
  224. 別のエンコーディングを使用したい場合は、アクセサメソッド getEncoding
  225. および setEncoding で設定します。
  226. </para>
  227. </sect2>
  228. </sect1>
  229. <!--
  230. vim:se ts=4 sw=4 et:
  231. -->