Zend_Validate-Hostname.xml 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 24570 -->
  4. <sect2 id="zend.validate.set.hostname">
  5. <title>ホスト名</title>
  6. <para>
  7. <classname>Zend_Validate_Hostname</classname> は、ホスト名が仕様を満たしているかどうかの検証を行います。
  8. 三種類の形式のホスト名、つまり <acronym>DNS</acronym> ホスト名
  9. (たとえば <filename>domain.com</filename>)、IP アドレス (たとえば 1.2.3.4)
  10. そしてローカルホスト名 (たとえば localhost) の検証が可能です。
  11. デフォルトでは <acronym>DNS</acronym> ホスト名のみが有効となります。
  12. </para>
  13. <sect3 id="zend.validate.set.hostname.options">
  14. <title>Zend_Validate_Hostname でサポートされるオプション</title>
  15. <para>
  16. <classname>Zend_Validate_Hostname</classname> では、下記のオプションがサポートされます。
  17. </para>
  18. <itemizedlist>
  19. <listitem>
  20. <para>
  21. <emphasis><property>allow</property></emphasis>:
  22. 使用できるホスト名のソートを定義します。
  23. 詳しくは、<link linkend="zend.validate.set.hostname.types">ホスト名の種類</link> をご覧ください。
  24. </para>
  25. </listitem>
  26. <listitem>
  27. <para>
  28. <emphasis><property>idn</property></emphasis>:
  29. <acronym>IDN</acronym> ドメインが許可されるかどうか定義します。
  30. このオプションのデフォルトは <constant>TRUE</constant> です。
  31. </para>
  32. </listitem>
  33. <listitem>
  34. <para>
  35. <emphasis><property>ip</property></emphasis>:
  36. これにより、固有の IP バリデーターを定義できます。
  37. このオプションのデフォルトは <classname>Zend_Validate_Ip</classname> の新規インスタンスです。
  38. </para>
  39. </listitem>
  40. <listitem>
  41. <para>
  42. <emphasis><property>tld</property></emphasis>:
  43. <acronym>TLD</acronym> が検証されるかどうか定義します。
  44. このオプションのデフォルトは <constant>TRUE</constant> です。
  45. </para>
  46. </listitem>
  47. </itemizedlist>
  48. </sect3>
  49. <sect3 id="zend.validate.set.hostname.basic">
  50. <title>基本的な使用法</title>
  51. <para>
  52. 基本的な使用法は、以下のようになります。
  53. </para>
  54. <programlisting language="php"><![CDATA[
  55. $validator = new Zend_Validate_Hostname();
  56. if ($validator->isValid($hostname)) {
  57. // ホスト名は正しい形式のようです
  58. } else {
  59. // 不正な形式なので、理由を表示します
  60. foreach ($validator->getMessages() as $message) {
  61. echo "$message\n";
  62. }
  63. }
  64. ]]></programlisting>
  65. <para>
  66. これは、ホスト名 <varname>$hostname</varname> を検証し、失敗した場合は
  67. その原因を表す便利なエラーメッセージを
  68. <methodname>$validator->getMessages()</methodname> で取得します。
  69. </para>
  70. </sect3>
  71. <sect3 id="zend.validate.set.hostname.types">
  72. <title>さまざまな形式のホスト名を検証</title>
  73. <para>
  74. IP アドレスやローカルホスト名、あるいはその両方を正しいホスト名として認めたいこともあるでしょう。
  75. その場合は、<classname>Zend_Validate_Hostname</classname> のインスタンスを作成する際にパラメータを渡します。
  76. このパラメータには、どの形式のホスト名を許可するのかを表す整数値を指定しなければなりません。
  77. できるだけ、<classname>Zend_Validate_Hostname</classname> の定数を使用するようにしましょう。
  78. </para>
  79. <para>
  80. <classname>Zend_Validate_Hostname</classname> の定数は次のとおりです。
  81. <constant>ALLOW_DNS</constant> は <acronym>DNS</acronym> ホスト名のみ、
  82. <constant>ALLOW_IP</constant> は IP アドレス、
  83. <constant>ALLOW_LOCAL</constant> はローカルネットワーク名、
  84. <constant>ALLOW_URI</constant> は <ulink
  85. url="http://tools.ietf.org/html/rfc3986">RFC3986</ulink> に準拠するアドレス、
  86. <constant>ALLOW_ALL</constant> は前述の4種類のすべて、
  87. を許可します。
  88. </para>
  89. <note>
  90. <title>ALLOW_URI に関する追加情報</title>
  91. <para>
  92. <constant>ALLOW_URI</constant> により、<ulink
  93. url="http://tools.ietf.org/html/rfc3986">RFC3986</ulink> に従うホスト名をチェックできます。
  94. これらは、<acronym>WINS</acronym>、NetInfo、および <filename>.hosts</filename>
  95. ファイル内で定義されるそれらのようなローカル・ホスト名によって使用される登録された名前です。
  96. </para>
  97. </note>
  98. <para>
  99. IP アドレスだけをチェックするには、以下の例のようにします。
  100. </para>
  101. <programlisting language="php"><![CDATA[
  102. $validator = new Zend_Validate_Hostname(Zend_Validate_Hostname::ALLOW_IP);
  103. if ($validator->isValid($hostname)) {
  104. // ホスト名は正しい形式のようです
  105. } else {
  106. // 不正な形式なので、理由を表示します
  107. foreach ($validator->getMessages() as $message) {
  108. echo "$message\n";
  109. }
  110. }
  111. ]]></programlisting>
  112. <para>
  113. <constant>ALLOW_ALL</constant> を使用して共通のすべてのホスト名形式を許可するほかに、
  114. これらの形式を組み合わせることもできます。
  115. たとえば、 <acronym>DNS</acronym> およびローカルホスト名を許可するには、
  116. <classname>Zend_Validate_Hostname</classname> のインスタンスを次のように作成します。
  117. </para>
  118. <programlisting language="php"><![CDATA[
  119. $validator = new Zend_Validate_Hostname(Zend_Validate_Hostname::ALLOW_DNS | Zend_Validate_Hostname::ALLOW_IP);]]></programlisting>
  120. </sect3>
  121. <sect3 id="zend.validate.set.hostname.idn">
  122. <title>国際化ドメイン名を検証</title>
  123. <para>
  124. 国別コードトップレベルドメイン (Country Code Top Level Domains: ccTLDs)
  125. の一部、たとえば 'de' (ドイツ) などでは、ドメイン名の中に国際化文字の使用をサポートしています。
  126. これは、国際化ドメイン名 (International Domain Names: <acronym>IDN</acronym>) といわれるものです。
  127. これらのドメインについても、<classname>Zend_Validate_Hostname</classname>
  128. の検証プロセスで使用する文字を拡張することで検証できます。
  129. </para>
  130. <note>
  131. <title>IDN ドメイン</title>
  132. <para>
  133. これまでに、50以上の ccTLD が <acronym>IDN</acronym> ドメインをサポートします。
  134. </para>
  135. </note>
  136. <para>
  137. <acronym>IDN</acronym> ドメインに対するマッチングを行う方法は、通常のホスト名の場合とまったく同じです。
  138. というのも、 <acronym>IDN</acronym> のマッチングはデフォルトで有効になっているからです。
  139. <acronym>IDN</acronym> の検証を無効にしたい場合は、<classname>Zend_Validate_Hostname</classname>
  140. のコンストラクタにパラメータを渡すか、あるいは
  141. <methodname>setValidateIdn()</methodname> メソッドを使用します。
  142. </para>
  143. <para>
  144. <acronym>IDN</acronym> の検証を無効にするには、<classname>Zend_Validate_Hostname</classname>
  145. のコンストラクタに二番目のパラメータを次のように渡します。
  146. </para>
  147. <programlisting language="php"><![CDATA[
  148. $validator =
  149. new Zend_Validate_Hostname(
  150. array(
  151. 'allow' => Zend_Validate_Hostname::ALLOW_DNS,
  152. 'idn' => false
  153. )
  154. );
  155. ]]></programlisting>
  156. <para>
  157. あるいは、 <constant>TRUE</constant> または <constant>FALSE</constant> を
  158. <methodname>setValidateIdn()</methodname> に渡すことで、
  159. <acronym>IDN</acronym> の検証を有効あるいは無効にすることもできます。
  160. 現在サポートされていない <acronym>IDN</acronym> ホスト名に対するマッチングを行おうとすると、
  161. 国際化文字が含まれている場合に検証に失敗します。
  162. 追加の文字を指定した ccTLD ファイルが <filename>Zend/Validate/Hostname</filename>
  163. に存在しない場合は、通常のホスト名の検証を行います。
  164. </para>
  165. <note>
  166. <title>IDN 検証</title>
  167. <para>
  168. <acronym>IDN</acronym> の検証は、 <acronym>DNS</acronym> ホスト名の検証を有効にしている場合にのみ行われることに注意しましょう。
  169. </para>
  170. </note>
  171. </sect3>
  172. <sect3 id="zend.validate.set.hostname.tld">
  173. <title>トップレベルドメインを検証</title>
  174. <para>
  175. デフォルトでは、ホスト名の検証は既知の <acronym>TLD</acronym> の一覧に基づいて行われます。
  176. この機能が不要な場合は、 <acronym>IDN</acronym> サポートを無効にするのと同じ方法で無効にできます。
  177. <acronym>TLD</acronym> の検証を無効にするには、<classname>Zend_Validate_Hostname</classname> のコンストラクタに三番目のパラメータを渡します。
  178. 以下の例では、 <acronym>IDN</acronym> の検証は二番目のパラメータで有効にしています。
  179. </para>
  180. <programlisting language="php"><![CDATA[
  181. $validator =
  182. new Zend_Validate_Hostname(
  183. array(
  184. 'allow' => Zend_Validate_Hostname::ALLOW_DNS,
  185. 'idn' => true,
  186. 'tld' => false
  187. )
  188. );
  189. ]]></programlisting>
  190. <para>
  191. あるいは、 <constant>TRUE</constant> または <constant>FALSE</constant> を
  192. <methodname>setValidateIdn()</methodname> に渡すことで、
  193. <acronym>TLD</acronym> の検証を有効あるいは無効にすることもできます。
  194. </para>
  195. <note>
  196. <title>TLD 検証</title>
  197. <para>
  198. <acronym>TLD</acronym> の検証は、 <acronym>DNS</acronym> ホスト名の検証を有効にしている場合にのみ行われることに注意しましょう。
  199. </para>
  200. </note>
  201. </sect3>
  202. </sect2>
  203. <!--
  204. vim:se ts=4 sw=4 et:
  205. -->