我在应用程序模块的引导程序中实现了一个逻辑,如果没有签名,它会将用户重定向到登录页面。我有
class Module
{
public function onBootstrap(MvcEvent $e)
{
$eventManager = $e->getApplication()->getEventManager();
$moduleRouteListener = new ModuleRouteListener();
$moduleRouteListener->attach($eventManager);
$session = new Container('signin');
if (!isset($session->member)){
$eventManager->attach(MvcEvent::EVENT_ROUTE, array($this,'routeMatched'), -100);
}
}
public function routeMatched(MvcEvent $e)
{
$match = $e->getRouteMatch();
// No route match, this is a 404
if (!$match instanceof RouteMatch) {
return;
}
$list = array('login', 'signin', 'upload');
// Route is whitelisted
$name = $match->getMatchedRouteName();
if (in_array($name, $list)) {
return;
}
// Redirect to the user login page, as an example
$router = $e->getRouter();
$url = $router->assemble(array(), array(
'name' => 'signin'
));
$response = $e->getResponse();
$response->getHeaders()->addHeaderLine('Location', $url);
$response->setStatusCode(302);
return $response;
}
}
如下所示,onBootstrap
内的代码将检查会话容器是否设置了member
变量,如果未设置,则附加EVENT_ROUTE,内部处理该怎么做取决于当前路线是否为白名单。
$session = new Container('signin');
if (!isset($session->member)) ...
这里的问题是$session->member
始终获得null
。我在我的控制器内部的登录操作中分配此变量,如此
if ($data->authenticate($member->email, $member->password)){
$session = new Container('signin');
$session->member = $member;
return $this->redirect()->toRoute('member-control-panel');
}else{
$view->setVariable('error', 'Could not verify user/password');
}
这里有什么问题?
更新
我按照威尔茨的回答提出修改。它仍然无法工作,但我稍微修改了代码以存储标量值(电子邮件)而不是对象(成员)。现在它正在工作所以问题是为什么会话容器不存储对象而只存储标量变量?
在我的登录操作中,我做了这样的更改
$session = new Container('signin');
//$session->member = $member; //removed
$session->email= $member->email; //New
在像这样的引导程序中
$session = new Container('signin');
if (!isset($session->email)){
$eventManager->attach(MvcEvent::EVENT_ROUTE, array($this,'routeMatched'), -100);
}
答案 0 :(得分:0)
正确处理会话只需要将变量转储到Container
实例中。会话无法在不序列化的情况下存储对象。这意味着您必须在从会话中解析它们时再次反序列化它们。
为了帮助您管理会话存储,ZF2有一个SessionManager
类我建议您创建一个SessionManager
来控制会话变量。您可以在official ZF2 docs on how to handle sessions correctly中阅读更多内容。
你像这样引导会话:
use Zend\Session\SessionManager;
use Zend\Session\Container;
class Module
{
public function onBootstrap($event)
{
$eventManager = $e->getApplication()->getEventManager();
$moduleRouteListener = new ModuleRouteListener();
$moduleRouteListener->attach($eventManager);
$this->bootstrapSession($event);
}
public function bootstrapSession($e)
{
$session = $e->getApplication()
->getServiceManager()
->get('Zend\Session\SessionManager');
$session->start();
$container = new Container('signin');
}
}
如果您的$member
是一个学说实体,我还建议您阅读the Doctrine 2 documentation on storing entities in the session