Zend_Uri.xml 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 15103 -->
  4. <sect1 id="zend.uri.chapter">
  5. <title>Zend_Uri</title>
  6. <sect2 id="zend.uri.overview">
  7. <title>概要</title>
  8. <para>
  9. <classname>Zend_Uri</classname> は、
  10. <ulink url="http://www.w3.org/Addressing/">Uniform Resource
  11. Identifiers</ulink> (URIs) の操作および検証を行うためのコンポーネントです。
  12. <classname>Zend_Uri</classname> の本来の目的は
  13. <classname>Zend_Http_Client</classname> のような他のコンポーネントを支援することですが、
  14. 単体で使用しても便利です。
  15. </para>
  16. <para>
  17. URI の最初は常にスキームから始まり、その後にコロンが続きます。
  18. スキームにはさまざまなものがあります。
  19. <classname>Zend_Uri</classname> クラスは、
  20. 各スキームに特化した自身のサブクラスを返すファクトリメソッドを提供しています。
  21. サブクラスの名前は <classname>Zend_Uri_&lt;scheme&gt;</classname>
  22. となり、<code>&lt;scheme&gt;</code> の部分には
  23. スキーム名の最初の文字だけを大文字にしたものがあてはまります。
  24. この規則にはひとつ例外があり、HTTPS スキームについては
  25. <classname>Zend_Uri_Http</classname> で扱われます。
  26. </para>
  27. </sect2>
  28. <sect2 id="zend.uri.creation">
  29. <title>新しい URI の作成</title>
  30. <para>
  31. スキームのみを <classname>Zend_Uri::factory()</classname> に渡すと、
  32. <classname>Zend_Uri</classname> は新しい URI をゼロから作成します。
  33. </para>
  34. <example id="zend.uri.creation.example-1">
  35. <title><classname>Zend_Uri::factory()</classname> による新しい URI の作成</title>
  36. <programlisting role="php"><![CDATA[
  37. // 何もないところから新しい URI を作成するには、スキームのみを渡します
  38. $uri = Zend_Uri::factory('http');
  39. // $uri は Zend_Uri_Http のインスタンスとなります
  40. ]]>
  41. </programlisting>
  42. </example>
  43. <para>
  44. 新しい URI を作成するには、スキームのみを
  45. <classname>Zend_Uri::factory()</classname> に渡します
  46. <footnote><para>現時点では、
  47. Zend_Uri がサポートしているスキームは HTTP および HTTPS だけです。</para></footnote>。
  48. サポートしていないスキームが渡された場合は、
  49. <classname>Zend_Uri_Exception</classname> がスローされます。
  50. </para>
  51. <para>
  52. 渡されたスキームあるいは URI をサポートしている場合は、
  53. <classname>Zend_Uri::factory()</classname> は自分自身のサブクラスを返します。
  54. これは、指定したスキームに特化したものとなります。
  55. </para>
  56. </sect2>
  57. <sect2 id="zend.uri.manipulation">
  58. <title>既存の URI の操作</title>
  59. <para>
  60. 既存の URI を操作するには、完全な URI を
  61. <classname>Zend_Uri::factory()</classname> に渡します。
  62. </para>
  63. <example id="zend.uri.manipulation.example-1">
  64. <title><classname>Zend_Uri::factory()</classname> による既存の URI の操作</title>
  65. <programlisting role="php"><![CDATA[
  66. // 既存の URI を操作するには、それを渡します
  67. $uri = Zend_Uri::factory('http://www.zend.com');
  68. // $uri は Zend_Uri_Http のインスタンスです
  69. ]]>
  70. </programlisting>
  71. </example>
  72. <para>
  73. このとき、URI のパースと検証が行われます。
  74. もし妥当な形式でなかった場合は、そこで
  75. <classname>Zend_Uri_Exception</classname> がスローされます。それ以外の場合は
  76. <classname>Zend_Uri::factory()</classname> は自分自身のサブクラスを返します。
  77. これは、操作するスキームに特化したものとなります。
  78. </para>
  79. </sect2>
  80. <sect2 id="zend.uri.validation">
  81. <title>URI の検証</title>
  82. <para>
  83. <classname>Zend_Uri::check()</classname> 関数を使用すると、
  84. 既存の URI の検証のみを行うことができます。
  85. </para>
  86. <example id="zend.uri.validation.example-1">
  87. <title><classname>Zend_Uri::check()</classname> による URI の検証</title>
  88. <programlisting role="php"><![CDATA[
  89. // 指定した URI が正しい形式かどうかを調べます
  90. $valid = Zend_Uri::check('http://uri.in.question');
  91. // $valid は、正しければ TRUE、そうでなければ FALSE となります
  92. ]]>
  93. </programlisting>
  94. </example>
  95. <para>
  96. <classname>Zend_Uri::check()</classname> は boolean 値を返します。
  97. これは <classname>Zend_Uri::factory()</classname>
  98. を使用して例外を処理するよりも便利です。
  99. </para>
  100. <sect3 id="zend.uri.validation.allowunwise">
  101. <title>URL 内での "Unwise" 文字の許可</title>
  102. <para>
  103. デフォルトでは、Zend_Uri は次の文字を許可しません。
  104. <code>"{", "}", "|", "\", "^", "`"</code>
  105. これらは RFC で "unwise" と定義されており無効なものです。
  106. しかし、多くの実装ではこれらの文字を妥当なものとして扱います。
  107. </para>
  108. <para>
  109. Zend_Uri でもこれらの "unwise" 文字を許可することができます。
  110. そのためには、Zend_Uri::setConfig() メソッドで
  111. 'allow_unwise' オプションを TRUE に設定します。
  112. </para>
  113. <example id="zend.uri.validation.allowunwise.example-1">
  114. <title>URI における特殊文字の許可</title>
  115. <programlisting role="php"><![CDATA[
  116. // '|' 記号を含んでいます
  117. // 通常は、これは false を返します
  118. $valid = Zend_Uri::check('http://example.com/?q=this|that');
  119. // しかし、"unwise" 文字を許可することもできます
  120. Zend_Uri::setConfig(array('allow_unwise' => true));
  121. // これは 'true' を返します
  122. $valid = Zend_Uri::check('http://example.com/?q=this|that');
  123. // 'allow_unwise' の値をデフォルトの FALSE に戻します
  124. Zend_Uri::setConfig(array('allow_unwise' => false));
  125. ]]>
  126. </programlisting>
  127. </example>
  128. <note>
  129. <para><classname>Zend_Uri::setConfig()</classname> は、全体の設定オプションを変更します。
  130. そのため、上の例のように最後は 'allow_unwise' を 'false'
  131. に戻すことを推奨します。unwise な文字を常に許可したいという場合は別です。</para>
  132. </note>
  133. </sect3>
  134. </sect2>
  135. <sect2 id="zend.uri.instance-methods">
  136. <title>共通のインスタンスメソッド</title>
  137. <para>
  138. すべての <classname>Zend_Uri</classname> のサブクラス (例
  139. <classname>Zend_Uri_Http</classname>) のインスタンスには、
  140. URI 操作のために便利なインスタンスメソッドがいくつか提供されています。
  141. </para>
  142. <sect3 id="zend.uri.instance-methods.getscheme">
  143. <title>URI のスキームの取得</title>
  144. <para>
  145. URI のスキームとは、URI でカンマの前にくる部分のことです。
  146. たとえば <code>http://www.zend.com</code> のスキームは
  147. <code>http</code> となります。
  148. </para>
  149. <example id="zend.uri.instance-methods.getscheme.example-1">
  150. <title><classname>Zend_Uri_*</classname> オブジェクトからのスキームの取得</title>
  151. <programlisting role="php"><![CDATA[
  152. $uri = Zend_Uri::factory('http://www.zend.com');
  153. $scheme = $uri->getScheme(); // "http"
  154. ]]>
  155. </programlisting>
  156. </example>
  157. <para>
  158. インスタンスメソッド <code>getScheme()</code> は、
  159. URI オブジェクトからスキームの部分のみを返します。
  160. </para>
  161. </sect3>
  162. <sect3 id="zend.uri.instance-methods.geturi">
  163. <title>URI 全体の取得</title>
  164. <example id="zend.uri.instance-methods.geturi.example-1">
  165. <title><classname>Zend_Uri_*</classname> オブジェクトからの URI 全体の取得</title>
  166. <programlisting role="php"><![CDATA[
  167. $uri = Zend_Uri::factory('http://www.zend.com');
  168. echo $uri->getUri(); // "http://www.zend.com"
  169. ]]>
  170. </programlisting>
  171. </example>
  172. <para>
  173. <code>getUri()</code> メソッドは、URI 全体を文字列として返します。
  174. </para>
  175. </sect3>
  176. <sect3 id="zend.uri.instance-methods.valid">
  177. <title>URI の検証</title>
  178. <para>
  179. <classname>Zend_Uri::factory()</classname> は渡された URI を常に検証しており、
  180. 渡された URI が無効な場合は <classname>Zend_Uri</classname>
  181. のサブクラスのインスタンスを作成しません。しかし、いったん
  182. <classname>Zend_Uri</classname> のサブクラスのインスタンスを
  183. (新規に、あるいは既存のものから) 作成し、
  184. それを操作した後でもまだ妥当な形式であるかどうかを調べることもできます。
  185. </para>
  186. <example id="zend.uri.instance-methods.valid.example-1">
  187. <title><classname>Zend_Uri_*</classname> オブジェクトの検証</title>
  188. <programlisting role="php"><![CDATA[
  189. $uri = Zend_Uri::factory('http://www.zend.com');
  190. $isValid = $uri->valid(); // TRUE
  191. ]]>
  192. </programlisting>
  193. </example>
  194. <para>
  195. インスタンスメソッド <code>valid()</code> により、
  196. URI オブジェクトが妥当なものかどうかを調べることができます。
  197. </para>
  198. </sect3>
  199. </sect2>
  200. </sect1>
  201. <!--
  202. vim:se ts=4 sw=4 et:
  203. -->