File: Zend_Config-Introduction.xml

package info (click to toggle)
zendframework 1.12.9%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: jessie-kfreebsd
  • size: 133,584 kB
  • sloc: xml: 1,311,829; php: 570,173; sh: 170; makefile: 125; sql: 121
file content (116 lines) | stat: -rw-r--r-- 4,416 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
<?xml version="1.0" encoding="utf-8"?>
<!-- EN-Revision: 24249 -->
<!-- Reviewed: no -->
<sect1 id="zend.config.introduction">
    <title>Introduction</title>

    <para>
        <classname>Zend_Config</classname> 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
        <classname>Zend_Config</classname> fournit des adaptateurs pour les données de
        configuration qui sont stockées dans des fichier textes avec
        <link linkend="zend.config.adapters.ini"><classname>Zend_Config_Ini</classname></link> et
        <link linkend="zend.config.adapters.xml"><classname>Zend_Config_Xml</classname></link>.
    </para>

    <example id="zend.config.introduction.example.using">
        <title>Utilisation native de Zend_Config</title>

        <para>
            Normalement on s'attend à ce que les utilisateurs emploient une des classes
            d'adaptateur telles que
            <link linkend="zend.config.adapters.ini"><classname>Zend_Config_Ini</classname></link>
            ou
            <link linkend="zend.config.adapters.xml"><classname>Zend_Config_Xml</classname></link>,
            mais si les données de configuration sont disponibles dans un tableau
            <acronym>PHP</acronym>, on peut
            simplement passer les données au constructeur de <classname>Zend_Config</classname>
            afin d'utiliser une interface orientée objet simple&#160;:
        </para>

        <programlisting language="php"><![CDATA[
// Fourni un tableau de configuration
$configArray = array(
    'webhost' => 'www.example.com',
    'database' => array(
        'adapter' => 'pdo_mysql',
        'params'  => array(
            'host'     => 'db.example.com',
            'username' => 'dbuser',
            'password' => 'secret',
            'dbname'   => 'mydatabase'
        )
    )
);

// Crée un objet à partir des données de configuration
$config = new Zend_Config($configArray);

// Affiche une donnée de configuration en particulier
// (résultat : 'www.example.com')
echo $config->webhost;

// Utilise les données de configuration pour se connecter
// à une base de données
$db = Zend_Db::factory($config->database->adapter,
                       $config->database->params->toArray());

// Autre possibilité : fournir simplement l'objet Zend_Config.
// Zend_Db factory sait comment l'interpréter.
$db = Zend_Db::factory($config->database);
]]></programlisting>

    </example>

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

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

    <programlisting language="php"><![CDATA[
$host = $config->database->get('host', 'localhost');
]]></programlisting>

    <example id="zend.config.introduction.example.file.php">
        <title>Utilisez Zend_Config avec un fichier de configuration en PHP</title>

        <para>
            Il est souvent souhaitable d'utiliser une fichier de configuration en pur
            <acronym>PHP</acronym>. Le code
            suivant illustre comment ceci peut être facilement réalisé&#160;:
        </para>

        <programlisting language="php"><![CDATA[
// config.php
return array(
    'webhost'  => 'www.example.com',
    'database' => array(
        'adapter' => 'pdo_mysql',
        'params'  => array(
            'host'     => 'db.example.com',
            'username' => 'dbuser',
            'password' => 'secret',
            'dbname'   => 'mydatabase'
        )
    )
);
]]></programlisting>

        <programlisting language="php"><![CDATA[
// Lecture de la configuration
$config = new Zend_Config(require 'config.php');

// Affiche une donnée de configuration ('www.example.com')
echo $config->webhost;
]]></programlisting>
    </example>
</sect1>