Zend_Validate-Hostname.xml 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 14978 -->
  4. <sect2 id="zend.validate.set.hostname">
  5. <title>ホスト名</title>
  6. <para>
  7. Zend_Validate_Hostname は、ホスト名が仕様を満たしているかどうかの検証を行います。
  8. 三種類の形式のホスト名、つまりDNS ホスト名
  9. (たとえば domain.com)、IP アドレス (たとえば 1.2.3.4)
  10. そしてローカルホスト名 (たとえば localhost) の検証が可能です。
  11. デフォルトでは DNS ホスト名のみが有効となります。
  12. </para>
  13. <para>
  14. <emphasis role="strong">基本的な使用法</emphasis>
  15. </para>
  16. <para>
  17. 基本的な使用法は、以下のようになります。
  18. <programlisting role="php"><![CDATA[
  19. $validator = new Zend_Validate_Hostname();
  20. if ($validator->isValid($hostname)) {
  21. // ホスト名は正しい形式のようです
  22. } else {
  23. // 不正な形式なので、理由を表示します
  24. foreach ($validator->getMessages() as $message) {
  25. echo "$message\n";
  26. }
  27. }
  28. ]]>
  29. </programlisting>
  30. これは、ホスト名 <code>$hostname</code> を検証し、失敗した場合は
  31. その原因を表す便利なエラーメッセージを
  32. <code>$validator->getMessages()</code> で取得します。
  33. </para>
  34. <para>
  35. <emphasis role="strong">さまざまな形式のホスト名の検証</emphasis>
  36. </para>
  37. <para>
  38. IP アドレスやローカルホスト名、あるいはその両方を正しいホスト名として認めたいこともあるでしょう。
  39. その場合は、Zend_Validate_Hostname のインスタンスを作成する際にパラメータを渡します。
  40. このパラメータには、どの形式のホスト名を許可するのかを表す整数値を指定しなければなりません。
  41. できるだけ、Zend_Validate_Hostname の定数を使用するようにしましょう。
  42. </para>
  43. <para>
  44. Zend_Validate_Hostname の定数は次のとおりです。<code>ALLOW_DNS</code> は DNS ホスト名のみを許可し、
  45. <code>ALLOW_IP</code> は IP アドレスを許可します。また <code>ALLOW_LOCAL</code>
  46. はローカルネットワーク名を許可し、<code>ALLOW_ALL</code> はこれら三種類をすべて許可します。
  47. IP アドレスだけをチェックするには、以下の例のようにします。
  48. <programlisting role="php"><![CDATA[
  49. $validator = new Zend_Validate_Hostname(Zend_Validate_Hostname::ALLOW_IP);
  50. if ($validator->isValid($hostname)) {
  51. // ホスト名は正しい形式のようです
  52. } else {
  53. // 不正な形式なので、理由を表示します
  54. foreach ($validator->getMessages() as $message) {
  55. echo "$message\n";
  56. }
  57. }
  58. ]]>
  59. </programlisting>
  60. </para>
  61. <para>
  62. <code>ALLOW_ALL</code> を使用してすべての形式を許可するほかに、
  63. これらの形式を組み合わせることもできます。
  64. たとえば、DNS およびローカルホスト名を許可するには、
  65. Zend_Validate_Hostname のインスタンスを次のように作成します。
  66. <programlisting role="php"><![CDATA[
  67. $validator = new Zend_Validate_Hostname(Zend_Validate_Hostname::ALLOW_DNS | Zend_Validate_Hostname::ALLOW_IP);]]>
  68. </programlisting>
  69. </para>
  70. <para>
  71. <emphasis role="strong">国際化ドメイン名の検証</emphasis>
  72. </para>
  73. <para>
  74. 国別コードトップレベルドメイン (Country Code Top Level Domains: ccTLDs)
  75. の一部、たとえば 'de' (ドイツ) などでは、ドメイン名の中に国際化文字の使用をサポートしています。
  76. これは、国際化ドメイン名 (International Domain Names: IDN) といわれるものです。
  77. これらのドメインについても、Zend_Validate_Hostname
  78. の検証プロセスで使用する文字を拡張することで検証することができます。
  79. </para>
  80. <para>
  81. 現在は、次のような ccTLD をサポートしています。
  82. <itemizedlist>
  83. <listitem>
  84. <para>at (オーストリア)</para>
  85. </listitem>
  86. <listitem>
  87. <para>ch (スイス)</para>
  88. </listitem>
  89. <listitem>
  90. <para>li (リヒテンシュタイン)</para>
  91. </listitem>
  92. <listitem>
  93. <para>de (ドイツ)</para>
  94. </listitem>
  95. <listitem>
  96. <para>fi (フィンランド)</para>
  97. </listitem>
  98. <listitem>
  99. <para>hu (ハンガリー)</para>
  100. </listitem>
  101. <listitem>
  102. <para>no (ノルウェー)</para>
  103. </listitem>
  104. <listitem>
  105. <para>se (スウェーデン)</para>
  106. </listitem>
  107. </itemizedlist>
  108. </para>
  109. <para>
  110. IDN ドメインに対するマッチングを行う方法は、通常のホスト名の場合とまったく同じです。
  111. というのも、IDN のマッチングはデフォルトで有効になっているからです。
  112. IDN の検証を無効にしたい場合は、Zend_Validate_Hostname
  113. のコンストラクタにパラメータを渡すか、あるいは
  114. <code>$validator->setValidateIdn()</code> メソッドを使用します。
  115. </para>
  116. <para>
  117. IDN の検証を無効にするには、Zend_Validate_Hostname
  118. のコンストラクタに二番目のパラメータを次のように渡します。
  119. <programlisting role="php"><![CDATA[
  120. $validator = new Zend_Validate_Hostname(Zend_Validate_Hostname::ALLOW_DNS, false);]]>
  121. </programlisting>
  122. あるいは、TRUE または FALSE を
  123. <code>$validator->setValidateIdn()</code> に渡すことで、
  124. IDN の検証を有効あるいは無効にすることもできます。
  125. 現在サポートされていない IDN ホスト名に対するマッチングを行おうとすると、
  126. 国際化文字が含まれている場合に検証に失敗します。
  127. 追加の文字を指定した ccTLD ファイルが Zend/Validate/Hostname
  128. に存在しない場合は、通常のホスト名の検証を行います。
  129. </para>
  130. <para>
  131. IDN の検証は、DNS ホスト名の検証を有効にしている場合にのみ行われることに注意しましょう。
  132. </para>
  133. <para>
  134. <emphasis role="strong">トップレベルドメインの検証</emphasis>
  135. </para>
  136. <para>
  137. デフォルトでは、ホスト名の検証は既知の TLD の一覧に基づいて行われます。
  138. この機能が不要な場合は、IDN サポートを無効にするのと同じ方法で無効にすることができます。
  139. TLD の検証を無効にするには、Zend_Validate_Hostname のコンストラクタに三番目のパラメータを渡します。
  140. 以下の例では、IDN の検証は二番目のパラメータで有効にしています。
  141. <programlisting role="php"><![CDATA[
  142. $validator = new Zend_Validate_Hostname(Zend_Validate_Hostname::ALLOW_DNS, true, false);]]>
  143. </programlisting>
  144. あるいは、TRUE または FALSE を
  145. <code>$validator->ValidateTld()</code> に渡すことで、
  146. TLD の検証を有効あるいは無効にすることもできます。
  147. </para>
  148. <para>
  149. TLD の検証は、DNS ホスト名の検証を有効にしている場合にのみ行われることに注意しましょう。
  150. </para>
  151. </sect2>
  152. <!--
  153. vim:se ts=4 sw=4 et:
  154. -->