Zend_Config_Ini.xml 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 24249 -->
  4. <sect1 id="zend.config.adapters.ini">
  5. <title>Zend_Config_Ini(日本語)</title>
  6. <para>
  7. <classname>Zend_Config_Ini</classname> は、おなじみの <acronym>INI</acronym>
  8. 形式のファイルに保存された設定データを、<classname>Zend_Config</classname>
  9. を通じてオブジェクトのプロパティとして扱えるようにします。
  10. この <acronym>INI</acronym> 形式は、階層化された設定データを扱うこと、
  11. そしてセクション間の継承関係を扱うことに特化されています。
  12. 設定データの階層構造は、キーの名前をドットあるいはピリオド
  13. (<emphasis>.</emphasis>) で区切ることによって表現します。
  14. 他のセクションを拡張するなどの継承関係は、
  15. セクション名に続けてコロン (<emphasis>:</emphasis>) を、
  16. そしてその後に継承元のセクション名を指定することで表します。
  17. </para>
  18. <note>
  19. <title>INI ファイルのパース</title>
  20. <para>
  21. <classname>Zend_Config_Ini</classname> は、<acronym>PHP</acronym> の
  22. <ulink url="http://php.net/parse_ini_file"><methodname>parse_ini_file()</methodname></ulink>
  23. 関数を使用しています。このドキュメントでは、<classname>Zend_Config_Ini</classname>
  24. 固有の挙動に注意しましょう。例えば、特殊な値として
  25. "<constant>TRUE</constant>" や "<constant>FALSE</constant>"、
  26. "yes"、"no" そして "<constant>NULL</constant>"
  27. を処理できることなどです。
  28. </para>
  29. </note>
  30. <note>
  31. <title>キーの区切り文字</title>
  32. <para>
  33. デフォルトでは、キーの区切り文字はピリオド (<emphasis>.</emphasis>) です。
  34. しかし、これは変更することもできます。変更するには、
  35. <classname>Zend_Config_Ini</classname> オブジェクトの作成時に
  36. <varname>$options</varname> のキー
  37. <property>nestSeparator</property> を設定します。たとえばこのようになります。
  38. </para>
  39. <programlisting language="php"><![CDATA[
  40. $options['nestSeparator'] = ':';
  41. $config = new Zend_Config_Ini('/path/to/config.ini',
  42. 'staging',
  43. $options);
  44. ]]>
  45. </programlisting>
  46. </note>
  47. <example id="zend.config.adapters.ini.example.using">
  48. <title>Zend_Config_Ini の使用法</title>
  49. <para>
  50. この例は、<classname>Zend_Config_Ini</classname> を使用して
  51. <acronym>INI</acronym> ファイルから設定データを読み込むための基本的な方法を説明するものです。
  52. この例では、運用環境の設定と開発環境の設定を両方管理しています。
  53. 開発環境用の設定データは運用環境用のものと非常に似ているので、
  54. 開発環境用のセクションは運用環境用のセクションを継承させています。
  55. 今回の場合なら、逆に運用環境用のセクションを開発環境用のものから継承させてもいいでしょう。
  56. そうしたからといって特に状況が複雑になるわけではありません。
  57. ここでは、次のような内容の設定データが
  58. <filename>/path/to/config.ini</filename> に存在するものとします。
  59. </para>
  60. <programlisting language="ini"><![CDATA[
  61. ; 運用環境の設定データ
  62. [production]
  63. webhost = www.example.com
  64. database.adapter = pdo_mysql
  65. database.params.host = db.example.com
  66. database.params.username = dbuser
  67. database.params.password = secret
  68. database.params.dbname = dbname
  69. ; 開発環境の設定データは、運用環境のデータを継承したうえで
  70. ; 必要に応じて値を上書きします
  71. [staging : production]
  72. database.params.host = dev.example.com
  73. database.params.username = devuser
  74. database.params.password = devsecret
  75. ]]>
  76. </programlisting>
  77. <para>
  78. 次に、開発者が開発環境用の設定データを <acronym>INI</acronym> ファイルから読み込むことを考えます。
  79. これは簡単なことで、単に <acronym>INI</acronym> ファイルとセクションを指定するだけです。
  80. </para>
  81. <programlisting language="php"><![CDATA[
  82. $config = new Zend_Config_Ini('/path/to/config.ini', 'staging');
  83. echo $config->database->params->host; // "dev.example.com" と出力します
  84. echo $config->database->params->dbname; // "dbname" と出力します
  85. ]]>
  86. </programlisting>
  87. </example>
  88. <note>
  89. <table id="zend.config.adapters.ini.table">
  90. <title>Zend_Config_Ini コンストラクタのパラメータ</title>
  91. <tgroup cols="2">
  92. <thead>
  93. <row>
  94. <entry>パラメータ</entry>
  95. <entry>説明</entry>
  96. </row>
  97. </thead>
  98. <tbody>
  99. <row>
  100. <entry><varname>$filename</varname></entry>
  101. <entry>読み込む <acronym>INI</acronym> ファイル。</entry>
  102. </row>
  103. <row>
  104. <entry><varname>$section</varname></entry>
  105. <entry>
  106. <acronym>INI</acronym> ファイル内で読み込む [section]。
  107. このパラメータを <constant>NULL</constant> にすると、
  108. すべてのセクションを読み込みます。
  109. また、セクション名の配列を指定すると、複数のセクションを読み込みます。
  110. </entry>
  111. </row>
  112. <row>
  113. <entry><varname>$options</varname> (デフォルトは <constant>FALSE</constant>)</entry>
  114. <entry>オプションの配列。以下のキーをサポートしています。
  115. <itemizedlist>
  116. <listitem>
  117. <para>
  118. <emphasis><property>allowModifications</property></emphasis>:
  119. <constant>TRUE</constant> を指定すると、
  120. 読み込んだ設定データをインメモリで後で変更できます。
  121. デフォルトは <constant>FALSE</constant> です。
  122. </para>
  123. </listitem>
  124. <listitem>
  125. <para>
  126. <emphasis><property>nestSeparator</property></emphasis>:
  127. ネストの区切り文字として使用する文字を設定します。
  128. デフォルトは "." です。
  129. </para>
  130. </listitem>
  131. </itemizedlist>
  132. </entry>
  133. </row>
  134. </tbody>
  135. </tgroup>
  136. </table>
  137. </note>
  138. </sect1>
  139. <!--
  140. vim:se ts=4 sw=4 et:
  141. -->