Zend_Config_Ini.xml 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. <sect1 id="zend.config.adapters.ini">
  2. <title>Zend_Config_Ini</title>
  3. <para>
  4. <code>Zend_Config_Ini</code>允许开发者通过嵌套的对象属性语法在应用程序中用熟悉的 INI 格式存储和读取配置数据。INI 格式在提供拥有配置数据键的等级结构和配置数据节之间的继承能力方面具有专长。配置数据等级结构通过用点或者句号 (<code>.</code>)分离键值。一个节可以扩展或者通过在节的名称之后带一个冒号(<code>:</code>)和被继承的配置数据的节的名称来从另一个节继承。
  5. </para>
  6. <note>
  7. <title>parse_ini_file</title>
  8. <para>
  9. <code>Zend_Config_Ini</code> 使用<ulink url="http://php.net/parse_ini_file"><code>parse_ini_file()</code></ulink>PHP 函数。请复习这个文档了解它的特定行为,它在<code>Zend_Config_Ini</code>中使用,例如<code>true</code>, <code>false</code>, <code>yes</code>, <code>no</code> 和 <code>null</code> 这些特殊的值如何操作。
  10. </para>
  11. </note>
  12. <note>
  13. <title>键分离器</title>
  14. <para>
  15. 缺省地,键分离器字符是句号(<code>.</code>)。然而,这个可以通过当构造<code>Zend_Config_Ini</code>对象时修改<code>$options</code> key <code>'nestSeparator'</code> 被修改。例如:
  16. <programlisting role="php"><![CDATA[
  17. $options['nestSeparator'] = ':';
  18. $config = new Zend_Config_Ini('/path/to/config.ini',
  19. 'staging',
  20. $options);
  21. ]]>
  22. </programlisting>
  23. </para>
  24. </note>
  25. <example id="zend.config.adapters.ini.example.using">
  26. <title>使用 Zend_Config_Ini</title>
  27. <para>
  28. 这个例子示例了从 INI 文件加载配置数据的<code>Zend_Config_Ini</code>的基本用法。在这个例子中有生产系统(production system)和开发系统(staging system)的配置数据。因为开发系统配置数据和生产系统的配置数据类似,所以开发系统的节从生产系统的节继承。在这个案例中,结果(decision)是任意的并且它可以反过来做,即生产系统节从开发系统节继承,尽管这不可能用于更复杂的情形。接着,假定下面的配置数据包含在<code>/path/to/config.ini</code>中:
  29. </para>
  30. <programlisting role="ini"><![CDATA[
  31. ; 生产站点配置数据
  32. [production]
  33. webhost = www.example.com
  34. database.adapter = pdo_mysql
  35. database.params.host = db.example.com
  36. database.params.username = dbuser
  37. database.params.password = secret
  38. database.params.dbname = dbname
  39. ; 开发站点配置数据从生产站点配置数据集成并如果需要可以重写
  40. [staging : production]
  41. database.params.host = dev.example.com
  42. database.params.username = devuser
  43. database.params.password = devsecret
  44. ]]>
  45. </programlisting>
  46. <para>
  47. 接着,假定开发者需要从INI文件取开发配置数据。这非常简单,只要指定INI文件和开发系统节就可以加载这些数据了:
  48. </para>
  49. <programlisting role="php"><![CDATA[
  50. $config = new Zend_Config_Ini('/path/to/config.ini', 'staging');
  51. echo $config->database->params->host; // 输出 "dev.example.com"
  52. echo $config->database->params->dbname; // 输出 "dbname"
  53. ]]>
  54. </programlisting>
  55. </example>
  56. <note>
  57. <table id="zend.config.adapters.ini.table">
  58. <title>Zend_Config_Ini 构造器参数</title>
  59. <tgroup cols="2">
  60. <thead>
  61. <row>
  62. <entry>参数</entry>
  63. <entry>注释</entry>
  64. </row>
  65. </thead>
  66. <tbody>
  67. <row>
  68. <entry><code>$filename</code></entry>
  69. <entry>要加载的 INI 文件。</entry>
  70. </row>
  71. <row>
  72. <entry><code>$section</code></entry>
  73. <entry>在INI文件中 [section] (节)将被加载。把这个参数设置为null,所有的节将被加载。另外,一个节名称的数组被提供给加载多个节。</entry>
  74. </row>
  75. <row>
  76. <entry><code>$options = false</code></entry>
  77. <entry>选项数组。下面的键被支持:
  78. <itemizedlist>
  79. <listitem><para><emphasis>allowModifications</emphasis>:设置为true 允许随后加载文件更改。缺省为false </para></listitem>
  80. <listitem><para><emphasis>nestSeparator</emphasis>: 设置嵌套字符。缺省为"."</para></listitem>
  81. </itemizedlist>
  82. </entry>
  83. </row>
  84. </tbody>
  85. </tgroup>
  86. </table>
  87. </note>
  88. </sect1>
  89. <!--
  90. vim:se ts=4 sw=4 et:
  91. -->