ZF2 セッションとタイムアウトで、奇妙で苛立たしい動作が見られます。
セッションをセットアップするために使用するコードは次のとおりです。
$sessionConfig = new \Zend\Session\Config\StandardConfig();
$sessionConfig->setOptions(array(
'cache_expire' => 525949,
'cookie_domain' => 'mydomain.com',
'cookie_lifetime' => 31536000,
'cookie_path' => '/',
'cookie_secure' => TRUE,
'gc_maxlifetime' => 31536000,
'name' => 'mydomain',
'remember_me_seconds' => 31536000,
'use_cookies' => TRUE,
));
$sessionManager = new \Zend\Session\SessionManager($sessionConfig);
$sessionManager->rememberMe(31536000);
$sessionManager->setSaveHandler(new \Zend\Session\SaveHandler\MongoDB($mongo, $options);
$session = new \Zend\Session\Container('MY_SESSION', $sessionManager);
このコードを実行すると、Cookie が作成されますが、有効期限はセッションの終わりです。
次のようにコードを変更すると:
$sessionManager = new \Zend\Session\SessionManager();
$sessionManager->rememberMe(31536000);
$sessionManager->setConfig($sessionConfig);
$session = new \Zend\Session\Container('MY_SESSION', $sessionManager);
Cookie が作成され、有効期限は 1 年後です。
ただし、Cookie が残っていても、セッションは 30 分ほどで期限切れになります。
私が望むのは、Cookie とセッションの両方が 1 年間持続することです。ZF2でこれを達成するにはどうすればよいですか?