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