Zend_Config-Introduction.xml 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <!-- EN-Revision: 15617 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.config.introduction">
  5. <title>Introduction</title>
  6. <para>
  7. <classname>Zend_Config</classname> est conçu pour simplifier l'accès et l'utilisation des
  8. données de configuration dans les applications. Il fournit une interface utilisateur basée
  9. sur des propriétés d'objets imbriquées. Les données de configuration peuvent venir de
  10. sources variées supportant une organisation hiérarchique des données. Actuellement
  11. <classname>Zend_Config</classname> fournit des adaptateurs pour les données de
  12. configuration qui sont stockées dans des fichier textes avec
  13. <link linkend="zend.config.adapters.ini"><classname>Zend_Config_Ini</classname></link> et
  14. <link linkend="zend.config.adapters.xml"><classname>Zend_Config_Xml</classname></link>.
  15. </para>
  16. <example id="zend.config.introduction.example.using">
  17. <title>Utilisation native de Zend_Config</title>
  18. <para>
  19. Normalement on s'attend à ce que les utilisateurs emploient une des classes
  20. d'adaptateur telles que
  21. <link linkend="zend.config.adapters.ini"><classname>Zend_Config_Ini</classname></link>
  22. ou
  23. <link linkend="zend.config.adapters.xml"><classname>Zend_Config_Xml</classname></link>,
  24. mais si les données de configuration sont disponibles dans un tableau PHP, on peut
  25. simplement passer les données au constructeur de <classname>Zend_Config</classname>
  26. afin d'utiliser une interface orientée objet simple&#160;:
  27. </para>
  28. <programlisting language="php"><![CDATA[
  29. // Fourni un tableau de configuration
  30. $configArray = array(
  31. 'webhost' => 'www.example.com',
  32. 'database' => array(
  33. 'adapter' => 'pdo_mysql',
  34. 'params' => array(
  35. 'host' => 'db.example.com',
  36. 'username' => 'dbuser',
  37. 'password' => 'secret',
  38. 'dbname' => 'mydatabase'
  39. )
  40. )
  41. );
  42. // Crée un objet à partir des données de configuration
  43. $config = new Zend_Config($configArray);
  44. // Affiche une donnée de configuration en particulier
  45. // (résultat : 'www.example.com')
  46. echo $config->webhost;
  47. // Utilise les données de configuration pour se connecter
  48. // à une base de données
  49. $db = Zend_Db::factory($config->database->adapter,
  50. $config->database->params->toArray());
  51. // Autre possibilité : fournir simplement l'objet Zend_Config.
  52. // Zend_Db factory sait comment l'interpréter.
  53. $db = Zend_Db::factory($config->database);
  54. ]]></programlisting>
  55. </example>
  56. <para>
  57. Comme illustré dans l'exemple ci-dessus, <classname>Zend_Config</classname> fournit une
  58. syntaxe de propriétés d'objets imbriquées pour accéder aux données de configuration passées
  59. à son constructeur.
  60. </para>
  61. <para>
  62. Avec l'accès de type orienté-objet aux données, <classname>Zend_Config</classname> a aussi
  63. la méthode <code>get()</code> qui retournera la valeur par défaut si l'élément n'existe
  64. pas. Par exemple&#160;:
  65. </para>
  66. <programlisting language="php"><![CDATA[
  67. $host = $config->database->get('host', 'localhost');
  68. ]]></programlisting>
  69. <example id="zend.config.introduction.example.file.php">
  70. <title>Utilisez Zend_Config avec un fichier de configuration en PHP</title>
  71. <para>
  72. Il est souvent souhaitable d'utiliser une fichier de configuration en pur PHP. Le code
  73. suivant illustre comment ceci peut être facilement réalisé&#160;:
  74. </para>
  75. <programlisting language="php"><![CDATA[
  76. // config.php
  77. return array(
  78. 'webhost' => 'www.example.com',
  79. 'database' => array(
  80. 'adapter' => 'pdo_mysql',
  81. 'params' => array(
  82. 'host' => 'db.example.com',
  83. 'username' => 'dbuser',
  84. 'password' => 'secret',
  85. 'dbname' => 'mydatabase'
  86. )
  87. )
  88. );
  89. ]]></programlisting>
  90. <programlisting language="php"><![CDATA[
  91. // Lecture de la configuration
  92. $config = new Zend_Config(require 'config.php');
  93. // Affiche une donnée de configuration ('www.example.com')
  94. echo $config->webhost;
  95. ]]></programlisting>
  96. </example>
  97. </sect1>