私はZend_Authのセッションバックエンドを変更しようとしています。しかしそれを成功させることはできませんでした。 私の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);
問題なくmemcacheの値を正常に保存していました。私はそれをテストする。
$namespace = new Zend_Session_Namespace();
$namespace->name = "Fatih";
他のコントローラでは、
$ns = new Zend_Session_Namespace();
var_dump($ns->name);
それは大丈夫ですが、私はmemcacheの中にZend_Authの値を参照してくださいcouldntの..しかし、私var_dump($_SESSION)
場合、私はそれが好きで見ることができます。
["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 } } }
ここで私のログイン方法を見ることができます。
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ワニスサーバが問題の原因であることが判明しました。 URLへの簡単な配管は固定されています。 –
私はmemcachedにセッションデータを保存しませんが、そこにとどまるという保証はありません。 –
私は懸念を見て、あなたはそのような問題のために何を使用しますか?たとえば、4つのWebサーバーがセッションデータを共有する必要があります。 –