Zend_Config_Xml.xml 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 15617 -->
  4. <sect1 id="zend.config.adapters.xml">
  5. <title>Zend_Config_Xml</title>
  6. <para>
  7. <classname>Zend_Config_Xml</classname> を使用すると、シンプルな XML
  8. 形式で保存した設定データを、オブジェクトのプロパティとして扱えるようになります。
  9. XML ファイルあるいは文字列のルート要素は設定には関係しないので、任意の名前がつけられます。
  10. その直下のレベルの XML 要素が設定データのセクションに対応します。
  11. セクションレベルの要素の下に XML 要素を配置することで、
  12. 階層構造をサポートします。
  13. 末端レベルの XML 要素が設定データの値に対応します。
  14. セクションの継承は、XML の属性 <code>extends</code>
  15. でサポートされます。この属性の値が、
  16. データを継承しているセクション名を表します。
  17. </para>
  18. <note>
  19. <title>返り値の型</title>
  20. <para>
  21. <classname>Zend_Config_Xml</classname> で読み込んだ設定データは、
  22. 常に文字列形式で返されます。必要に応じて、
  23. 文字列から適切な型に変換してください。
  24. </para>
  25. </note>
  26. <example id="zend.config.adapters.xml.example.using">
  27. <title>Zend_Config_Xml の使用法</title>
  28. <para>
  29. この例は、<classname>Zend_Config_Xml</classname> を使用して
  30. XML ファイルから設定データを読み込むための基本的な方法を説明するものです。
  31. この例では、運用環境の設定と開発環境の設定を両方管理しています。
  32. 開発環境用の設定データは運用環境用のものと非常に似ているので、
  33. 開発環境用のセクションは運用環境用のセクションを継承させています。
  34. 今回の場合なら、逆に運用環境用のセクションを開発環境用のものから継承させてもいいでしょう。
  35. そうしたからといって特に状況が複雑になるわけではありません。
  36. ここでは、次のような内容の設定データが
  37. <code>/path/to/config.xml</code> に存在するものとします。
  38. </para>
  39. <programlisting language="xml"><![CDATA[
  40. <?xml version="1.0"?>
  41. <configdata>
  42. <production>
  43. <webhost>www.example.com</webhost>
  44. <database>
  45. <adapter>pdo_mysql</adapter>
  46. <params>
  47. <host>db.example.com</host>
  48. <username>dbuser</username>
  49. <password>secret</password>
  50. <dbname>dbname</dbname>
  51. </params>
  52. </database>
  53. </production>
  54. <staging extends="production">
  55. <database>
  56. <params>
  57. <host>dev.example.com</host>
  58. <username>devuser</username>
  59. <password>devsecret</password>
  60. </params>
  61. </database>
  62. </staging>
  63. </configdata>
  64. ]]></programlisting>
  65. <para>
  66. 次に、開発者が開発環境用の設定データを XML ファイルから読み込むことを考えます。
  67. これは簡単なことで、単に XML ファイルとセクションを指定するだけです。
  68. </para>
  69. <programlisting language="php"><![CDATA[
  70. $config = new Zend_Config_Xml('/path/to/config.xml', 'staging');
  71. echo $config->database->params->host; // "dev.example.com" と出力します
  72. echo $config->database->params->dbname; // "dbname" と出力します
  73. ]]></programlisting>
  74. </example>
  75. <example id="zend.config.adapters.xml.example.attributes">
  76. <title>Zend_Config_Xml におけるタグの属性の使用</title>
  77. <para>
  78. <classname>Zend_Config_Xml</classname> では、設定内でノードを定義する際にさらに 2 通りの方法を用意しています。
  79. どちらも属性を使用するものです。<code>extends</code> 属性や
  80. <code>value</code> 属性は予約語
  81. (後者は、属性を使う 2 番目の方法で使用します)
  82. となり、使用できません。属性を使用する方法のひとつは、
  83. 親ノードに属性を追加するものです。
  84. これが、そのノードの子と見なされます。
  85. </para>
  86. <programlisting language="xml"><![CDATA[
  87. <?xml version="1.0"?>
  88. <configdata>
  89. <production webhost="www.example.com">
  90. <database adapter="pdo_mysql">
  91. <params host="db.example.com" username="dbuser" password="secret" dbname="dbname"/>
  92. </database>
  93. </production>
  94. <staging extends="production">
  95. <database>
  96. <params host="dev.example.com" username="devuser" password="devsecret"/>
  97. </database>
  98. </staging>
  99. </configdata>
  100. ]]></programlisting>
  101. <para>
  102. もうひとつの方法は、設定ファイルの記述量を減らすことはありません。
  103. ただ、同じタグ名を何度も書く必要がなくなるので保守性は上がります。
  104. 単純に空のタグを作成し、その値を <code>value</code>
  105. 属性に含めます。
  106. </para>
  107. <programlisting language="xml"><![CDATA[
  108. <?xml version="1.0"?>
  109. <configdata>
  110. <production>
  111. <webhost>www.example.com</webhost>
  112. <database>
  113. <adapter value="pdo_mysql"/>
  114. <params>
  115. <host value="db.example.com"/>
  116. <username value="dbuser"/>
  117. <password value="secret"/>
  118. <dbname value="dbname"/>
  119. </params>
  120. </database>
  121. </production>
  122. <staging extends="production">
  123. <database>
  124. <params>
  125. <host value="dev.example.com"/>
  126. <username value="devuser"/>
  127. <password value="devsecret"/>
  128. </params>
  129. </database>
  130. </staging>
  131. </configdata>
  132. ]]></programlisting>
  133. </example>
  134. <note>
  135. <title>XML 文字列</title>
  136. <para>
  137. <classname>Zend_Config_Xml</classname> は、データベースなどから取得した
  138. XML 文字列を直接読み込むこともできます。
  139. 文字列はコンストラクタの最初のパラメータとして渡し、最初は
  140. <code>'&lt;?xml'</code> で始まらなければなりません。
  141. </para>
  142. <programlisting language="xml"><![CDATA[
  143. $string = <<<EOT
  144. <?xml version="1.0"?>
  145. <config>
  146. <production>
  147. <db>
  148. <adapter value="pdo_mysql"/>
  149. <params>
  150. <host value="db.example.com"/>
  151. </params>
  152. </db>
  153. </production>
  154. <staging extends="production">
  155. <db>
  156. <params>
  157. <host value="dev.example.com"/>
  158. </params>
  159. </db>
  160. </staging>
  161. </config>
  162. EOT;
  163. $config = new Zend_Config_Xml($string, 'staging');
  164. ]]></programlisting>
  165. </note>
  166. </sect1>
  167. <!--
  168. vim:se ts=4 sw=4 et:
  169. -->