Zend_Session_SaveHandler_DbTable

Das Basis Setup für Zend_Session_SaveHandler_DbTable muß zumindest vier Spalten haben, die wie folgt im Config Array oder Zend_Config Objekt beschrieben werden: primary, ist der Primary-Key und standardmäßig nur die SessionID welche standardmäßig ein String der Länge 32 ist; modified, ist der Unix-Timestamp des Datums der letzten Änderung; lifetime, ist die Lebenszeit der Session (modified + lifetime > time();); und data, sind die serialisierten Daten die in der Session gespeichert werden.

Beispiel 892. Basis Setup

CREATE TABLE `session` (
  `id` char(32),
  `modified` int,
  `lifetime` int,
  `data` text,
  PRIMARY KEY (`id`)
);
// Datenbank Verbindung vorbereiten
$db = Zend_Db::factory('Pdo_Mysql', array(
    'host'     =>'example.com',
    'username' => 'dbuser',
    'password' => '******',
    'dbname'   => 'dbname'
));

// Entweder den Standardadapter Zend_Db_Table setzen
// oder eine DB-Verbindung direkt an den save Handler $config übergeben
Zend_Db_Table_Abstract::setDefaultAdapter($db);
$config = array(
    'name'           => 'session',
    'primary'        => 'id',
    'modifiedColumn' => 'modified',
    'dataColumn'     => 'data',
    'lifetimeColumn' => 'lifetime'
);

// Erstellen der Zend_Session_SaveHandler_DbTable und
// Setzen des save Handlers für Zend_Session
Zend_Session::setSaveHandler(new Zend_Session_SaveHandler_DbTable($config));

// Session starten
Zend_Session::start();

// Jetzt kann Zend_Session wie sonst verwendet werden

Man kann auch mehrere Spalten im Primarykey für Zend_Session_SaveHandler_DbTable verwenden.

Beispiel 893. Mehr-Spalten Primary-Keys verwenden

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`)
);
// Die DB Verbindung wie vorher einrichten
// BEACHTE: Diese Config wird auch an Zend_Db_Table übergeben sodas
// spezielles für die Tabelle genauso in die Config gegeben werden kann
$config = array(
    'name'              => 'session', // Tabellenname von Zend_Db_Table
    'primary'           => array(
        'session_id',   // Die SessionID von PHP
        'save_path',    // session.save_path
        'name',         // Session Name
    ),
    'primaryAssignment' => array(
        // Man muß dem Save-Handler mitteilen welche Spalten man als
        // Primary-Key verwendet. DIE REIHENFOLGE IST WICHITG
        'sessionId', // Erste Spalte des Primary-Keys ist die sessionID
        'sessionSavePath', // Zweite Spalte des Primary-Keys ist der save-path
        'sessionName', // Dritte Spalte des Primary-Keys ist der Session Name
    ),
    'modifiedColumn' => 'modified', // Zeit nach der die Session abläuft
    'dataColumn'     => 'session_data', // Serialisierte Daten
    'lifetimeColumn' => 'lifetime', // Lebensende für einen speziellen Eintrag
);

// Zend_Session mitteilen das der Save Handler verwendet werden soll
Zend_Session::setSaveHandler(new Zend_Session_SaveHandler_DbTable($config));

// Session starten
Zend_Session::start();

// Zend_Session wie normal verwenden