Zend_Validate-Hostname.xml 7.2 KB

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