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.
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);
'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.
Example #2 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
'name' => 'session', // Tabellenname von Zend_Db_Table
'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
|
|