Gestion générale de la session

Zend_Session_SaveHandler_DbTable

Le paramétrage basique pour Zend_Session_SaveHandler_DbTable doit contenir au moins quatre colonnes, décrites dans une configuration de type array ou objet Zend_Config : "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.

Example #1 Paramétrage basique

  1. CREATE TABLE `session` (
  2.   `id` char(32),
  3.   `modified` int,
  4.   `lifetime` int,
  5.   `data` text,
  6.   PRIMARY KEY (`id`)
  7. );
  1. // Préparation de l'adaptateur de connexion à la base de données
  2. $db = Zend_Db::factory('Pdo_Mysql', array(
  3.     'host'        =>'example.com',
  4.     'username'    => 'dbuser',
  5.     'password'    => '******',
  6.     'dbname'    => 'dbname'
  7. ));
  8.  
  9. // Vous pouvez soit passer l'adaptateur par défaut à Zend_Db_Table
  10. // ou l'objet $db dans votre tableau $config
  11. Zend_Db_Table_Abstract::setDefaultAdapter($db);
  12. $config = array(
  13.     'name'           => 'session',
  14.     'primary'        => 'id',
  15.     'modifiedColumn' => 'modified',
  16.     'dataColumn'     => 'data',
  17.     'lifetimeColumn' => 'lifetime'
  18. );
  19.  
  20. // Création de votre Zend_Session_SaveHandler_DbTable
  21. // et paramétrage du gestionnaire de sauvegarde à Zend_Session
  22. Zend_Session::setSaveHandler(new Zend_Session_SaveHandler_DbTable($config));
  23.  
  24. // Démarrage de la session
  25. Zend_Session::start();
  26.  
  27. // Vous pouvez maintenant utiliser Zend_Session comme avant

Vous pouvez aussi utiliser des colonnes multiples pour votre clé primaire de Zend_Session_SaveHandler_DbTable.

Example #2 Utilisation d'une clé primaire multi-colonnes

  1. CREATE TABLE `session` (
  2.     `session_id` char(32) NOT NULL,
  3.     `save_path` varchar(32) NOT NULL,
  4.     `name` varchar(32) NOT NULL DEFAULT '',
  5.     `modified` int,
  6.     `lifetime` int,
  7.     `session_data` text,
  8.     PRIMARY KEY (`Session_ID`, `save_path`, `name`)
  9. );
  1. // Préparation de l'adaptateur de connexion à la base de données comme ci-dessus
  2. // NOTE : cette configuration est fournie à Zend_Db_Table donc tout élément spécifique à la table peut y être ajouté
  3. $config = array(
  4.     'name'              => 'session',
  5.     // Nom de la table comme pour Zend_Db_Table
  6.     'primary'           => array(
  7.         'session_id',
  8.         // l'ID de session fourni par PHP
  9.         'save_path',
  10.         // session.save_path
  11.         'name',
  12.         // session name
  13.     ),
  14.     'primaryAssignment' => array(
  15.     // vous devez avertir le gestionnaire de sauvegarde quelles colonnes
  16.     // vous utilisez en tant que clé primaire. L'ORDRE EST IMPORTANT.
  17.         'sessionId',
  18.         // - la première colonne de la clé primaire est l'ID de session
  19.         'sessionSavePath',
  20.         // - la seconde colonne de la clé primaire est le "save path"
  21.         'sessionName',
  22.         // - la troisième colonne de la clé primaire est le "session name"
  23.     ),
  24.     'modifiedColumn'    => 'modified',
  25.     // date de la dernière modification
  26.     'dataColumn'        => 'session_data',
  27.     // donnée sérialisée
  28.     'lifetimeColumn'    => 'lifetime',
  29.     // durée de vie de l'enregistrement
  30. );
  31.  
  32. // Informez Zend_Session d'utiliser votre gestionnaire de sauvegarde
  33. Zend_Session::setSaveHandler(
  34.     new Zend_Session_SaveHandler_DbTable($config)
  35. );
  36.  
  37. // Démarrage de la session
  38. Zend_Session::start();
  39.  
  40. // Utilisez Zend_Session normalement

Gestion générale de la session