Zend_Config_Xml.xml 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <sect1 id="zend.config.adapters.xml">
  4. <title>Zend_Config_Xml</title>
  5. <para>
  6. <classname>Zend_Config_Xml</classname> дает разработчикам возможность
  7. хранить конфигурационные данные в простом формате <acronym>XML</acronym> и читать их
  8. посредством синтаксиса вложенных свойств объектов.
  9. Корневой элемент в файле или строке с <acronym>XML</acronym> не имеет значения и ему
  10. может быть дано любое имя. Первый уровень
  11. элементов <acronym>XML</acronym> соответствует разделам конфигурационных данных. Формат
  12. <acronym>XML</acronym> поддерживает иерархическую организацию данных через вложенность
  13. элементов ниже элементов уровня разделов. Содержимое конечного элемента
  14. соответствует значению элемента конфигурационных данных. Наследование
  15. разделов поддерживается через специальный атрибут <emphasis>extends</emphasis>,
  16. значение атрибута соответствует разделу, данные которого наследуются в
  17. раздел с этим атрибутом.
  18. </para>
  19. <note>
  20. <title>Тип возвращаемых данных</title>
  21. <para>
  22. Конфигурационные данные, прочитанные в <classname>Zend_Config_Xml</classname>,
  23. всегда возвращаются как строки. Приведение данных из строк к требуемым
  24. типам предоставляется разработчикам.
  25. </para>
  26. </note>
  27. <example id="zend.config.adapters.xml.example.using">
  28. <title>Использование Zend_Config_Xml</title>
  29. <para>
  30. Данный пример демонстрирует основы использования <classname>Zend_Config_Xml</classname>
  31. для загрузки конфигурационных данных из файла <acronym>XML</acronym>. В этом примере
  32. используются конфигурационные данные для производственной и
  33. промежуточной систем. Поскольку конфигурационные данные
  34. промежуточной системы очень похожи на конфигурационные данные для
  35. производственной системы, то "промежуточный" (staging) раздел наследует от
  36. "производственного" (production) раздела. В данном случае выбор
  37. произвольный, т.е. может быть и наоборот — "производственный"
  38. раздел наследует от "промежуточного", хотя это может не подходить в
  39. более сложных случаях. Допустим, конфигурационные данные
  40. находятся в файле <filename>/path/to/config.xml</filename>:
  41. </para>
  42. <programlisting language="xml"><![CDATA[
  43. <?xml version="1.0"?>
  44. <configdata>
  45. <production>
  46. <webhost>www.example.com</webhost>
  47. <database>
  48. <adapter>pdo_mysql</adapter>
  49. <params>
  50. <host>db.example.com</host>
  51. <username>dbuser</username>
  52. <password>secret</password>
  53. <dbname>dbname</dbname>
  54. </params>
  55. </database>
  56. </production>
  57. <staging extends="production">
  58. <database>
  59. <params>
  60. <host>dev.example.com</host>
  61. <username>devuser</username>
  62. <password>devsecret</password>
  63. </params>
  64. </database>
  65. </staging>
  66. ]]></programlisting>
  67. <para>
  68. Далее предположим, что разработчику приложения нужны "промежуточные"
  69. конфигурационные данные из файла <acronym>XML</acronym>. Загрузить эти данные, указав
  70. файл <acronym>XML</acronym> и нужный раздел, довольно просто:
  71. </para>
  72. <programlisting language="php"><![CDATA[
  73. $config = new Zend_Config_Xml('/path/to/config.xml', 'staging');
  74. echo $config->database->params->host; // выведет "dev.example.com"
  75. echo $config->database->params->dbname; // выведет "dbname"
  76. ]]></programlisting>
  77. </example>
  78. <example id="zend.config.adapters.xml.example.attributes">
  79. <title>Использование тегов в <classname>Zend_Config_Xml</classname></title>
  80. <para>
  81. <classname>Zend_Config_Xml</classname> также поддерживает два дополнительных способа
  82. определения узлов в конфигурации. В обоих способах используются
  83. атрибуты. Поскольку атрибуты <emphasis>extends</emphasis> и
  84. <emphasis>value</emphasis> являются зарезервированными ключевыми словами
  85. (<emphasis>value</emphasis> используется во втором способе
  86. с применением атрибутов), то они не должны использоваться здесь.
  87. Первый способ с использованием атрибутов состоит в добавлении
  88. атрибутов в родительский узел, они потом будут преобразованы в
  89. потомки этого узла:
  90. </para>
  91. <programlisting language="xml"><![CDATA[
  92. <?xml version="1.0"?>
  93. <configdata>
  94. <production webhost="www.example.com">
  95. <database adapter="pdo_mysql">
  96. <params host="db.example.com" username="dbuser" password="secret"
  97. dbname="dbname"/>
  98. </database>
  99. </production>
  100. <staging extends="production">
  101. <database>
  102. <params host="dev.example.com" username="devuser"
  103. password="devsecret"/>
  104. </database>
  105. </staging>
  106. </configdata>
  107. ]]></programlisting>
  108. <para>
  109. Другой способ не делает конфигурацию заметно короче, но
  110. облегчает ее поддержку благодаря тому, что не нужно писать имена
  111. тегов дважды. Вы просто создаете пустой тег, значение которого
  112. содержится в атрибуте <emphasis>value</emphasis>:
  113. </para>
  114. <programlisting language="xml"><![CDATA[
  115. <?xml version="1.0"?>
  116. <configdata>
  117. <production>
  118. <webhost>www.example.com</webhost>
  119. <database>
  120. <adapter value="pdo_mysql"/>
  121. <params>
  122. <host value="db.example.com"/>
  123. <username value="dbuser"/>
  124. <password value="secret"/>
  125. <dbname value="dbname"/>
  126. </params>
  127. </database>
  128. </production>
  129. <staging extends="production">
  130. <database>
  131. <params>
  132. <host value="dev.example.com"/>
  133. <username value="devuser"/>
  134. <password value="devsecret"/>
  135. </params>
  136. </database>
  137. </staging>
  138. </configdata>
  139. ]]></programlisting>
  140. </example>
  141. <note>
  142. <title>Передача строки с XML</title>
  143. <para>
  144. <classname>Zend_Config_Xml</classname> также может загружать
  145. <acronym>XML</acronym> непосредственно из строки, которая может быть получена,
  146. например, из базы данных. Строка передается конструктору в качестве
  147. первого параметра и должна начинаться с символов
  148. <emphasis>'&lt;?xml'</emphasis>:
  149. </para>
  150. <programlisting language="xml"><![CDATA[
  151. $string = <<<EOT
  152. <?xml version="1.0"?>
  153. <config>
  154. <production>
  155. <db>
  156. <adapter value="pdo_mysql"/>
  157. <params>
  158. <host value="db.example.com"/>
  159. </params>
  160. </db>
  161. </production>
  162. <staging extends="production">
  163. <db>
  164. <params>
  165. <host value="dev.example.com"/>
  166. </params>
  167. </db>
  168. </staging>
  169. </config>
  170. EOT;
  171. $config = new Zend_Config_Xml($string, 'staging');
  172. ]]></programlisting>
  173. </note>
  174. </sect1>
  175. <!--
  176. vim:se ts=4 sw=4 et:
  177. -->