Zend_Config

Introduction

Zend_Config est conçu pour simplifier l'accès et l'utilisation des données de configuration dans les applications. Il fournit une interface utilisateur basée sur des propriétés d'objets imbriquées. Les données de configuration peuvent venir de sources variées supportant une organisation hiérarchique des données. Actuellement Zend_Config fournit des adaptateurs pour les données de configuration qui sont stockées dans des fichier textes avec Zend_Config_Ini et Zend_Config_Xml.

Example #1 Utilisation native de Zend_Config

Normalement on s'attend à ce que les utilisateurs emploient une des classes d'adaptateur telles que Zend_Config_Ini ou Zend_Config_Xml, mais si les données de configuration sont disponibles dans un tableau PHP, on peut simplement passer les données au constructeur de Zend_Config afin d'utiliser une interface orientée objet simple :

  1. // Fourni un tableau de configuration
  2. $configArray = array(
  3.     'webhost' => 'www.example.com',
  4.     'database' => array(
  5.         'adapter' => 'pdo_mysql',
  6.         'params'  => array(
  7.             'host'     => 'db.example.com',
  8.             'username' => 'dbuser',
  9.             'password' => 'secret',
  10.             'dbname'   => 'mydatabase'
  11.         )
  12.     )
  13. );
  14.  
  15. // Crée un objet à partir des données de configuration
  16. $config = new Zend_Config($configArray);
  17.  
  18. // Affiche une donnée de configuration en particulier
  19. // (résultat : 'www.example.com')
  20. echo $config->webhost;
  21.  
  22. // Utilise les données de configuration pour se connecter
  23. // à une base de données
  24. $db = Zend_Db::factory($config->database->adapter,
  25.                        $config->database->params->toArray());
  26.  
  27. // Autre possibilité : fournir simplement l'objet Zend_Config.
  28. // Zend_Db factory sait comment l'interpréter.
  29. $db = Zend_Db::factory($config->database);

Comme illustré dans l'exemple ci-dessus, Zend_Config fournit une syntaxe de propriétés d'objets imbriquées pour accéder aux données de configuration passées à son constructeur.

Avec l'accès de type orienté-objet aux données, Zend_Config a aussi la méthode get() qui retournera la valeur par défaut si l'élément n'existe pas. Par exemple :

  1. $host = $config->database->get('host', 'localhost');

Example #2 Utilisez Zend_Config avec un fichier de configuration en PHP

Il est souvent souhaitable d'utiliser une fichier de configuration en pur PHP. Le code suivant illustre comment ceci peut être facilement réalisé :

  1. // config.php
  2. return array(
  3.     'webhost'  => 'www.example.com',
  4.     'database' => array(
  5.         'adapter' => 'pdo_mysql',
  6.         'params'  => array(
  7.             'host'     => 'db.example.com',
  8.             'username' => 'dbuser',
  9.             'password' => 'secret',
  10.             'dbname'   => 'mydatabase'
  11.         )
  12.     )
  13. );
  1. // Lecture de la configuration
  2. $config = new Zend_Config(require 'config.php');
  3.  
  4. // Affiche une donnée de configuration ('www.example.com')
  5. echo $config->webhost;

Zend_Config