Zend_Config_Writer.xml 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <!-- EN-Revision: 20765 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.config.writer.introduction">
  5. <title>Zend_Config_Writer</title>
  6. <para>
  7. <classname>Zend_Config_Writer</classname> vous donne la possibilité d'écrire des
  8. fichiers de configuration à partir d'objets <classname>Zend_Config</classname>. Il
  9. fonctionne avec des adaptateurs détachés du système et est donc très simple à utiliser. Par
  10. défaut <classname>Zend_Config_Writer</classname> embarque trois adaptateurs, qui
  11. fonctionnent tous sur la base de fichiers. Vous instanciez un rédacteur ("writer") avec des
  12. options spécifiques, qui peuvent être <emphasis>filename</emphasis> et
  13. <emphasis>config</emphasis>. Ensuite
  14. vous pouvez appeler la méthode <methodname>write()</methodname> du rédacteur et le fichier
  15. de configuration est créé. Vous pouvez aussi fournir <varname>$filename</varname> et
  16. <varname>$config</varname> directement à la méthode <methodname>write()</methodname>.
  17. Actuellement les
  18. rédacteurs suivants sont embarqués avec <classname>Zend_Config_Writer</classname>&#160;:
  19. </para>
  20. <itemizedlist>
  21. <listitem>
  22. <para><classname>Zend_Config_Writer_Array</classname></para>
  23. </listitem>
  24. <listitem>
  25. <para><classname>Zend_Config_Writer_Ini</classname></para>
  26. </listitem>
  27. <listitem>
  28. <para><classname>Zend_Config_Writer_Xml</classname></para>
  29. </listitem>
  30. </itemizedlist>
  31. <para>
  32. Le rédacteur <acronym>INI</acronym> possède deux modes de rendu en fonction des sections.
  33. Par défaut la configuration de premier niveau est toujours écrite dans des noms de section.
  34. En appelant <command>$writer->setRenderWithoutSections();</command>, toutes les options
  35. sont écrites dans l'espace de noms global du fichier <acronym>INI</acronym> et aucune
  36. section n'est appliquée.
  37. </para>
  38. <para>
  39. De plus, <classname>Zend_Config_Writer_Ini</classname> a un
  40. paramètre optionnel additionnel <emphasis>nestSeparator</emphasis>, définissant le caractère
  41. séparant les profondeurs d'imbrication. Par défaut il s'agit du point,
  42. comme <classname>Zend_Config_Ini</classname> l'accepte par défaut.
  43. </para>
  44. <para>
  45. Lors de la modification ou la création d'objet <classname>Zend_Config</classname>, il
  46. y a quelques informations à garder en mémoire. Pour créer ou modifier une valeur, vous
  47. appelez simplement le réglage d'un paramètre d'un objet <classname>Zend_Config</classname>
  48. grâce à l'accesseur de paramètre ("<emphasis>-&gt;</emphasis>"). Pour créer une section à
  49. la racine ou pour créer une branche, vous avez juste à créer un nouveau tableau
  50. (<command>$config-&gt;branch = array();</command>). Pour définir quelle section en étend une
  51. autre, vous devez appeler la méthode <methodname>setExtend()</methodname> sur l'objet
  52. <classname>Zend_Config</classname> racine.
  53. </para>
  54. <example id="zend.config.writer.example.using">
  55. <title>Utilisation de Zend_Config_Writer</title>
  56. <para>
  57. Cet exemple illustre une utilisation basique
  58. <classname>Zend_Config_Writer_Xml</classname> pour créer un nouveau fichier de
  59. configuration&#160;:
  60. </para>
  61. <programlisting language="php"><![CDATA[
  62. // Créer l'objet de configuration
  63. $config = new Zend_Config(array(), true);
  64. $config->production = array();
  65. $config->staging = array();
  66. $config->setExtend('staging', 'production');
  67. $config->production->db = array();
  68. $config->production->db->hostname = 'localhost';
  69. $config->production->db->username = 'production';
  70. $config->staging->db = array();
  71. $config->staging->db->username = 'staging';
  72. // Ecrire le fichier de l'une des manières suivantes :
  73. // a)
  74. $writer = new Zend_Config_Writer_Xml(array('config' => $config,
  75. 'filename' => 'config.xml'));
  76. $writer->write();
  77. // b)
  78. $writer = new Zend_Config_Writer_Xml();
  79. $writer->setConfig($config)
  80. ->setFilename('config.xml')
  81. ->write();
  82. // c)
  83. $writer = new Zend_Config_Writer_Xml();
  84. $writer->write('config.xml', $config);
  85. ]]></programlisting>
  86. <para>
  87. Ceci créera un fichier de configuration <acronym>XML</acronym> avec les sections
  88. "production" et "staging", où "staging" étend "production".
  89. </para>
  90. </example>
  91. <example id="zend.config.writer.modifying">
  92. <title>Modifier une configuration existante</title>
  93. <para>
  94. Cet exemple montre comment modifier un fichier de configuration
  95. existant&#160;:
  96. </para>
  97. <programlisting language="php"><![CDATA[
  98. // Charger toutes les sections d'un fichier de configuration existant,
  99. // tout en évitant les sections étendues.
  100. $config = new Zend_Config_Ini('config.ini',
  101. null,
  102. array('skipExtends' => true,
  103. 'allowModifications' => true));
  104. // Modifier une valeur
  105. $config->production->hostname = 'foobar';
  106. // Ecrire le fichier
  107. $writer = new Zend_Config_Writer_Ini(array('config' => $config,
  108. 'filename' => 'config.ini'));
  109. $writer->write();
  110. ]]></programlisting>
  111. </example>
  112. <note>
  113. <title>Chargement d'un fichier de configuration</title>
  114. <para>
  115. Lors du chargement d'un fichier de configuration existant afin de le modifier, il
  116. est très important de charger toutes les sections et d'éviter les sections étendues,
  117. évitant ainsi toute fusion de valeurs. Ceci est réalisé en fournissant l'option
  118. <emphasis>skipExtends</emphasis> au constructeur.
  119. </para>
  120. </note>
  121. <para>
  122. Pour tous les rédacteurs à base de fichiers (<acronym>INI</acronym>, <acronym>XML</acronym>
  123. et tableau <acronym>PHP</acronym>), en interne la méthode <methodname>render()</methodname>
  124. est utilisée pour construire la chaîne de configuration. Cette méthode peut être utilisée
  125. en dehors de la classe si vous souhaitez accéder à une représentation textuelle de vos
  126. données de configuration.
  127. </para>
  128. </sect1>