File: Zend_Log-Formatters.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 (111 lines) | stat: -rw-r--r-- 4,901 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
<?xml version="1.0" encoding="UTF-8"?>
<!-- EN-Revision: 24249 -->
<!-- Reviewed: no -->
<sect1 id="zend.log.formatters">
    <title>Formateurs (mise en forme)</title>

    <para>
        Un formateur est un objet qui est responsable de prendre un tableau <code>event</code>
        décrivant un événement de log et produisant une ligne de log formatée sous la forme d'un une
        chaîne.
    </para>

    <para>
        Quelques rédacteurs ("Writers") ne fonctionnent pas en terme de ligne et ne peuvent
        pas utiliser un formateur. Un exemple est le rédacteur de base de données, qui insère les
        items d'événement directement en colonnes de base de données. Pour les rédacteurs qui ne
        peuvent pas supporter un formateur, une exception est levée si vous essayez d'affecter un
        formateur.
    </para>

    <sect2 id="zend.log.formatters.simple">
        <title>Formatage simple</title>

        <para>
            <classname>Zend_Log_Formatter_Simple</classname> est le formateur par défaut. Il
            est configuré automatiquement quand vous n'indiquez aucun formateur. La configuration
            par défaut est équivalente à ce qui suit : <programlisting language="php"><![CDATA[
$format = '%timestamp% %priorityName% (%priority%): %message%' . PHP_EOL;
$formatter = new Zend_Log_Formatter_Simple($format);
]]></programlisting></para>

        <para>
            Un formateur est affecté à un objet individuel de rédacteur en utilisant la
            méthode <methodname>setFormatter()</methodname> du rédacteur : <programlisting language="php"><![CDATA[
$redacteur = new Zend_Log_Writer_Stream('php://output');
$formateur = new Zend_Log_Formatter_Simple('Bonjour %message%' . PHP_EOL);
$redacteur->setFormatter($formateur);

$logger = new Zend_Log();
$logger->addWriter($redacteur);

$logger->info('Monde');

// affiche "Bonjour Monde"
]]></programlisting></para>

        <para>
            Le constructeur de <classname>Zend_Log_Formatter_Simple</classname> accepte un
            paramètre unique : la chaîne de formatage. Cette chaîne contient des clés entourées par
            le signe pourcentage (par exemple %message%). La chaîne de formatage peut contenir
            n'importe quelle clé du tableau de données d'événement. Vous pouvez récupérer les clés
            par défaut en utilisant la constante DEFAULT_FORMAT de
            <classname>Zend_Log_Formatter_Simple</classname>.
        </para>
    </sect2>

    <sect2 id="zend.log.formatters.xml">
        <title>Formater vers le XML</title>

        <para>
            <classname>Zend_Log_Formatter_Xml</classname> formate des données de log dans des
            chaînes de type XML. Par défaut, il note automatiquement tout le tableau de données
            d'événements : <programlisting language="php"><![CDATA[
$redacteur = new Zend_Log_Writer_Stream('php://output');
$formateur = new Zend_Log_Formatter_Xml();
$redacteur->setFormatter($formateur);

$logger = new Zend_Log();
$logger->addWriter($redacteur);

$logger->info("Message d'information");
]]></programlisting></para>

        <para>
            Le code ci-dessus affiche le XML suivant (des espaces supplémentaires sont ajoutés
            pour la clarté) : <programlisting language="xml"><![CDATA[
<logEntry>
  <timestamp>2007-04-06T07:24:37-07:00</timestamp>
  <message>Message d'information</message>
  <priority>6</priority>
  <priorityName>INFO</priorityName>
</logEntry>
]]></programlisting></para>

        <para>
            Il est possible d'adapter l'élément racine comme indiquent faire correspondre les
            éléments XML au tableau de données d'évènements. Le constructeur de
            <classname>Zend_Log_Formatter_Xml</classname> accepte une chaîne avec le nom de
            l'élément racine comme premier paramètre et un tableau associatif avec les éléments de
            correspondance comme deuxième paramètre : <programlisting language="php"><![CDATA[
$redacteur = new Zend_Log_Writer_Stream('php://output');
$formateur = new Zend_Log_Formatter_Xml('log',
                                        array('msg' => 'message',
                                              'niveau' => 'priorityName'));
$redacteur->setFormatter($formateur);

$logger = new Zend_Log();
$logger->addWriter($redacteur);

$logger->info("Message d'information");
]]></programlisting> Le code ci-dessus change l'élément racine par défaut de
            <code>logEntry</code> en <code>log</code>. Il fait correspondre également les éléments
            <code>msg</code> au <code>message</code> de l'item de donnée d'événement. Ceci a comme
            conséquence l'affichage suivant : <programlisting language="xml"><![CDATA[
<log>
  <msg>Message d'information</msg>
  <niveau>INFO</niveau>
</log>
]]></programlisting></para>
        </sect2>
    </sect1>