File: multiuser-sessions.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 (122 lines) | stat: -rw-r--r-- 5,760 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
117
118
119
120
121
122
<?xml version="1.0" encoding="UTF-8"?>
<!-- EN-Revision: 24249 -->
<!-- Reviewed: no -->
<sect1 id="learning.multiuser.sessions">
    <title>Gérer les sessions dans ZF</title>

    <sect2 id="learning.multiuser.sessions.intro">
        <title>Introduction aux sessions</title>

        <para>
            Le succès du web est en grande partie dûe aux protocoles qui le supportent: HTTP. HTTP sur
            TCP est par nature sans état ce qui signifie que le web n'a pas "de mémoire". Ce fait
            pose des problèmes pour les développeurs voulant traiter leur application comme un
            service riche.
        </para>

        <para>
            Interagir avec l'application web c'est en fait faire la somme de toutes les requêtes
            que celle-ci reçoit. Et comme il y a beaucoup de clients, il y a beaucoup de requête,
            et le moyen d'associer une requête à un client est appelé "session".
        </para>

        <para>
            En PHP, le problème des sessions a été résolu au travers de l'extension session qui utilise
            un système de persistance, typiquement basé sur des cookies et un stockage local des variables
            dans $_SESSION. Dans Zend Framework, le composant Zend_Session ajoute de la valeur au système
            de session de PHP notamment une manipulation objet.
        </para>
    </sect2>

    <sect2 id="learning.multiuser.sessions.basic-usage">
        <title>Utilisation classique de Zend_Session</title>

        <para>
            Le composant Zend_Session est un gestionnaire de session et une API pour stocker des données
            dans la session de manière objet. L'API de la classe Zend_Session API permet de régler des options
            et de démarrer/arrêter la session alors que Zend_Session_Namespace représente un objet
            contenant des données à stocker en session.
        </para>

        <para>
            C'est générallement une bonne pratique que de démarrer sa session en bootstrap, cependant
            la première création d'un objet Zend_Session_Namespace démarrera la session par défaut.
        </para>

        <para>
            Zend_Application peut permettre de configurer Zend_Session grâce aux parties
            Zend_Application_Resource. Pour les utiliser, en supposant que votre projet utilise
            Zend_Application, ajoutez le code suivant à application.ini:
        </para>

        <programlisting language="php"><![CDATA[
resources.session.save_path = APPLICATION_PATH "/../data/session"
resources.session.use_only_cookies = true
resources.session.remember_me_seconds = 864000
]]></programlisting>

        <para>
            Comme vous le remarquez, les options utilisées sont les mêmes que celles que reconnait
            ext/session (l'extension session de PHP). Le chemin de stockage des session par exemple.
            Les fichiers ini peuvent utiliser des constantes, nous réutilisons APPLICATION_PATH
            pour calculer le chemin relatif vers un dossier arbitraire sensé stocker les sessions.
        </para>

        <para>
            La plupart des composants de Zend Framework utilisant les sessions n'ont rien besoin de plus.
            Dès lors, vous pouvez utiliser un composant faisant appel à la session, ou manipuler la session
            vous-même au travers d'un ou plusieurs objets Zend_Session_Namespace.
        </para>

        <para>
            Zend_Session_Namespace est une classe qui guide ses données vers $_SESSION. La classe s'appelle
            Zend_Session_Namespace car elle crée des espaces de noms au sein de $_SESSION, autorisant
            plusieurs composants ou objets à stocker des valeurs sans se marcher dessus. Nous allons voir
            dans l'exemple qui suit comment créer un simple compteur de session qui commence à 1000
            et se remet à zéro après 1999.
        </para>

        <programlisting language="php"><![CDATA[
$mysession = new Zend_Session_Namespace('mysession');

if (!isset($mysession->counter)) {
    $mysession->counter = 1000;
} else {
    $mysession->counter++;
}

if ($mysession->counter > 1999) {
    unset($mysession->counter);
}
]]></programlisting>

        <para>
            Comme vous le remarquez, l'objet de session utilise les méthodes magiques __get, __set,
            __isset, et __unset pour proposer une API intuitive. Les informations stockées dans
            notre exemple le sont en réalité dans $_SESSION['mysession']['counter'].
        </para>
    </sect2>

    <sect2 id="learning.multiuser.sessions.advanced-usage">
        <title>Utilisation avancée de Zend_Session</title>

        <para>
            Si vous voulez utiliser le gestionnaire de sauvegarde des sessions "DbTable", vous
            pouvez simplement ajouter ces options à application.ini:
        </para>

        <programlisting language="php"><![CDATA[
resources.session.saveHandler.class = "Zend_Session_SaveHandler_DbTable"
resources.session.saveHandler.options.name = "session"
resources.session.saveHandler.options.primary.session_id = "session_id"
resources.session.saveHandler.options.primary.save_path = "save_path"
resources.session.saveHandler.options.primary.name = "name"
resources.session.saveHandler.options.primaryAssignment.sessionId = "sessionId"
resources.session.saveHandler.options.primaryAssignment.sessionSavePath = "sessionSavePath"
resources.session.saveHandler.options.primaryAssignment.sessionName = "sessionName"
resources.session.saveHandler.options.modifiedColumn = "modified"
resources.session.saveHandler.options.dataColumn = "session_data"
resources.session.saveHandler.options.lifetimeColumn = "lifetime"
]]></programlisting>
    </sect2>
</sect1>