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 123 124 125
|
<?xml version="1.0" encoding="UTF-8"?>
<!-- EN-Revision: 24249 -->
<!-- Reviewed: no -->
<sect1 id="zend.session.savehandler.dbtable">
<title>Zend_Session_SaveHandler_DbTable</title>
<para>
Le paramétrage basique pour <classname>Zend_Session_SaveHandler_DbTable</classname>
doit contenir au moins quatre colonnes, décrites dans une configuration de type
<code>array</code> ou objet <classname>Zend_Config</classname> : "primary" qui est la clé
primaire et reçoit par défaut l'ID de session dont le format est par défaut une chaîne de 32
caractères ; "modifiedColumn" qui est le timestamp Unix de la date de dernière modification
; "lifetimeColumn" qui est la durée de vie de la session ("modified" + "lifetime" doit être
supérieur à "time()") ; et "dataColumn" qui est la donnée sérialisée stockée en
session.
</para>
<example id="zend.session.savehandler.dbtable.basic">
<title>Paramétrage basique</title>
<programlisting language="SQL"><![CDATA[
CREATE TABLE `session` (
`id` char(32),
`modified` int,
`lifetime` int,
`data` text,
PRIMARY KEY (`id`)
);
]]></programlisting>
<programlisting language="php"><![CDATA[
// Préparation de l'adaptateur de connexion à la base de données
$db = Zend_Db::factory('Pdo_Mysql', array(
'host' =>'example.com',
'username' => 'dbuser',
'password' => '******',
'dbname' => 'dbname'
));
// Vous pouvez soit passer l'adaptateur par défaut à Zend_Db_Table
// ou l'objet $db dans votre tableau $config
Zend_Db_Table_Abstract::setDefaultAdapter($db);
$config = array(
'name' => 'session',
'primary' => 'id',
'modifiedColumn' => 'modified',
'dataColumn' => 'data',
'lifetimeColumn' => 'lifetime'
);
// Création de votre Zend_Session_SaveHandler_DbTable
// et paramétrage du gestionnaire de sauvegarde à Zend_Session
Zend_Session::setSaveHandler(new Zend_Session_SaveHandler_DbTable($config));
// Démarrage de la session
Zend_Session::start();
// Vous pouvez maintenant utiliser Zend_Session comme avant
]]></programlisting>
</example>
<para>
Vous pouvez aussi utiliser des colonnes multiples pour votre clé primaire de
<classname>Zend_Session_SaveHandler_DbTable</classname>.
</para>
<example id="zend.session.savehandler.dbtable.multi-column-key">
<title>Utilisation d'une clé primaire multi-colonnes</title>
<programlisting language="SQL"><![CDATA[
CREATE TABLE `session` (
`session_id` char(32) NOT NULL,
`save_path` varchar(32) NOT NULL,
`name` varchar(32) NOT NULL DEFAULT '',
`modified` int,
`lifetime` int,
`session_data` text,
PRIMARY KEY (`Session_ID`, `save_path`, `name`)
);
]]></programlisting>
<programlisting language="php"><![CDATA[
// Préparation de l'adaptateur de connexion à la base de données comme ci-dessus
// NOTE : cette configuration est fournie à Zend_Db_Table donc tout élément spécifique à la table peut y être ajouté
$config = array(
'name' => 'session',
// Nom de la table comme pour Zend_Db_Table
'primary' => array(
'session_id',
// l'ID de session fourni par PHP
'save_path',
// session.save_path
'name',
// session name
),
'primaryAssignment' => array(
// vous devez avertir le gestionnaire de sauvegarde quelles colonnes
// vous utilisez en tant que clé primaire. L'ORDRE EST IMPORTANT.
'sessionId',
// - la première colonne de la clé primaire est l'ID de session
'sessionSavePath',
// - la seconde colonne de la clé primaire est le "save path"
'sessionName',
// - la troisième colonne de la clé primaire est le "session name"
),
'modifiedColumn' => 'modified',
// date de la dernière modification
'dataColumn' => 'session_data',
// donnée sérialisée
'lifetimeColumn' => 'lifetime',
// durée de vie de l'enregistrement
);
// Informez Zend_Session d'utiliser votre gestionnaire de sauvegarde
Zend_Session::setSaveHandler(
new Zend_Session_SaveHandler_DbTable($config)
);
// Démarrage de la session
Zend_Session::start();
// Utilisez Zend_Session normalement
]]></programlisting>
</example>
</sect1>
|