To jest mój tabeli:Przechowywanie sesji w DB tabeli nie działa (używając Zend_Session_SaveHandler_DbTable)
CREATE TABLE `Sessions` (
`id` varchar(32) NOT NULL,
`modified` int(11) default NULL,
`lifetime` int(11) default NULL,
`data` text,
PRIMARY KEY (`id`)
) ENGINE=InnoDB
To w moim bootstrap:
$sessionConfig = array(
'name' => 'Sessions', //table name as per Zend_Db_Table
'primary' => 'id', //the sessionID given by php
'modifiedColumn' => 'modified', //time the session should expire
'dataColumn' => 'data', //serialized data
'lifetimeColumn' => 'lifetime' //end of life for a specific record
);
$saveHandler = new Zend_Session_SaveHandler_DbTable($sessionConfig);
//cookie persist for 30 days
Zend_Session::rememberMe($seconds = (60 * 60 * 24 * 30));
//make the session persist for 30 days
$saveHandler->setLifetime($seconds)
->setOverrideLifetime(true);
//similarly,
//$saveHandler->setLifetime($seconds, true);
Zend_Session::setSaveHandler($saveHandler);
Zend_Session::start();
Kiedy zalogować, nic nigdy nie jest wpisywane do Tabela sesji i jestem wylogowany na następnej odsłonie strony.
Wszelkie pomysły? Staram się, aby moi użytkownicy byli nieustannie zalogowani. Czy brakuje mi czegoś w moim kontrolerze logowania?
Przeczytałem, że chcesz wywołać Zend_Session :: start(); po wszystkim. Jednym z powodów, dla których sesja session_set_cookie_params() wywoływana z rememberMe() nie może ustawić czasu życia po uruchomieniu sesji. – Brian
Mimo to, jeśli ustawisz "Zend_Session :: start();" zanim cokolwiek innego to zadziała? To może dostarczyć nam wskazówek, co może przeszkadzać. – Frankie
Wprowadzanie Zend_Session :: start(); W związku z tym wszystko wydaje się dawać taki sam rezultat. Jakieś pomysły? – Brian