Sto provando a cambiare il backend di sessione di Zend_Auth. Ma non ci riuscirà. Nel mio bootstrap.php;
$oBackend = new Zend_Cache_Backend_Libmemcached(
array(
'servers' => $servers,
'compression' => false
));
// configure caching frontend strategy
$oFrontend = new Zend_Cache_Core(
array(
'caching' => true,
'automatic_serialization' => true
));
// build a caching object
$cache = Zend_Cache::factory($oFrontend, $oBackend);
$saveHandler = new \Application\Auth\Adapter\Memcached();
$saveHandler->setCacher($cache);
\Zend_Session::setSaveHandler($saveHandler);
Stava salvando i valori memcache senza alcun problema. Lo collaudo;
$namespace = new Zend_Session_Namespace();
$namespace->name = "Fatih";
In altri controller;
$ns = new Zend_Session_Namespace();
var_dump($ns->name);
E 'ok, ma non potevo vedere i valori Zend_Auth in memcache .. Ma se io var_dump($_SESSION)
riesco a vedere le cose come;
["Zend_Auth"]=> array(1) { ["storage"]=> object(Application_Security_Auth_Storage)#66 (1) { ["_user":protected]=> object(Application_Security_Auth_User)#84 (4) { ["id":protected]=> object(MongoId)#87 (1) { ["$id"]=> string(24) "4fcca6b8c863c79d33000004" } ["username":protected]=> string(5) "admin" ["role":protected]=> string(5) "admin" ["fullname":protected]=> NULL } } }
Qui è possibile visualizzare il mio metodo di accesso;
public function login($username, $password)
{
if ($username == "" || $password == "")
return false;
$adapter = new \Application_Security_Auth_Adapter();
$adapter->setIdentity($username);
$adapter->setCredential($password);
$auth = \Zend_Auth::getInstance();
$result = $auth->authenticate($adapter);
return $result->isValid();
}
Ok Si è scoperto che i nostri server di vernice sono la ragione del problema. Piping semplice per url è stato risolto. –
Non memorizzerei i dati di sessione su memcached, non c'è alcuna garanzia che rimanga lì. –
ok vedo la preoccupazione, cosa useresti per quel tipo di problema? Diciamo che 4 server web devono condividere i dati della sessione. –