实施新的应用程序ZF2我发现自己与eventmanager进行挣扎。 在应用模块我创建了一个AuthenticationListener
和NotifierListener
。 第一检查适当的认证的用户和所述第二显示器的自定义消息寻址到所述登录的用户。
现在,我创建调度XML文件导出一个新的模块。 我想保持AuthenticationListener
但卸下NotifierListener
避免E_NOTIFY
错误。 问题是,阅读博客/源代码/文档(相当差)和拉我的头发后,我无法理解如何卸下上面提到的听众。
应用module.php
public function onBootstrap($e)
{
$eventManager = $e->getApplication()->getEventManager();
$authListener = new AuthenticationListener();
$authListener->attach($eventManager);
$notifyListener = new NotifyListener();
$notifyListener->attach($eventManager);
}
新module.php
public function onBootstrap($e)
{
$eventManager = $e->getApplication()->getEventManager();
// ... $eventmanager->detach('NotifyListener');
}
答案是让你的听众服务
由于它不需要构造函数参数,可以是可调用的,所以把它的invokables阵列
public function getServiceConfig()
{
return array(
'invokables' => array(
'NotifyListener' => 'FQCN\To\NotifyListener',
),
);
}
从服务管理器获取它,而不是直接在你的引导创建一个新的实例
public function onBootstrap($e)
{
$eventManager = $e->getApplication()->getEventManager();
$sm = $e->getApplication()->getServiceManager();
$notifyListener = $sm->get('NotifyListener')
$notifyListener->attach($eventManager);
}
任何你想要脱离它,你只需要能够得到在的ServiceManager
// in any ServiceLocator aware class
$sm = $this->getServiceLocator();
$eventManager = $sm->get('Application')->getEventManager();
$notifyListener = $sm->get('NotifyListener');
$notifyListener->detach($eventManager);
你是在正确的道路上。 你需要做的唯一的事情就是调用detach()
在你的NotifyListener
上,而不是EvenManager
。 这个例子波纹管是源于为Zend框架手册EventManager
。
链接: http://framework.zend.com/manual/2.0/en/modules/zend.event-manager.event-manager.html#examples
use Zend\Cache\Cache;
use Zend\EventManager\EventCollection;
use Zend\EventManager\ListenerAggregateInterface;
use Zend\EventManager\EventInterface;
class CacheListener implements ListenerAggregateInterface
{
protected $cache;
protected $listeners = array();
public function __construct(Cache $cache)
{
$this->cache = $cache;
}
public function attach(EventCollection $events)
{
$this->listeners[] = $events->attach('get.pre', array($this, 'load'), 100);
$this->listeners[] = $events->attach('get.post', array($this, 'save'), -100);
}
public function detach(EventManagerInterface $events)
{
foreach ($this->listeners as $index => $listener) {
if ($events->detach($listener)) {
unset($this->listeners[$index]);
}
}
}
public function load(EventInterface $e)
{
// some code to load
}
public function save(EventInterface $e)
{
// some code to save
}
}
本实施例中很好地说明了如何准备监听器(例如AuthenticationListener
)实施ListenerAggregateInterface
。
假设同样的情况与你的Module
对象:
public function onBootstrap($e)
{
$eventManager = $e->getApplication()->getEventManager();
$cacheListener = new CacheListener($cache);
$cacheListener->detach($eventManager);
}
因此,假设您的NotifyListener
实现ListenerAggregateInterface
或只是有一个detach()
你可以写你的方法onBootstrap()
方法来分离侦听器是这样的:
public function onBootstrap($e)
{
$eventManager = $e->getApplication()->getEventManager();
$notifyListener = new NotifyListener();
$notifyListener->detach($eventManager);
}
希望这有助于反馈将不胜感激:)
斯托扬