如何在的ServiceManager在ZF2注册一个Zend \ Log实例

来源:互联网 发布:比较好用的浴帽知乎 编辑:程序博客网 时间:2024/06/09 20:59
我想知道什么是通过ZF2中的ServiceManager启动和重新使用记录器实例的最佳方式.

我在我的引导创建一个默认的数据库编写器对象,并在的ServiceManager注册它.

public function onBootstrap(MvcEvent $e)
{
...

$serviceManager = $e->getApplication()->getServiceManager();
$dbAdapter = $serviceManager->get('Zend\Db\Adapter\Adapter');

$writer = new \Zend\Log\Writer\Db($dbAdapter, 'log_database_table');
$logger = new \Zend\Log\Logger();
$logger->addWriter($writer);

// this is optional but nice to have
\Zend\Log\Logger::registerErrorHandler($logger);

$serviceManager->setService('Zend\Log', $logger);
}

在一个AbstractController是“ServiceLocatorAwareInterface”的一个实例.这样我就可以在我的控制器只需要调用

public function indexAction()
{
...

$this->getServiceLocator()->get('Zend\Log')->info('this is a test log message');

...
}


或者,更优雅,你可以设置一个日志侦听器,并保持你的记录从您的应用程序分离.该

EventManager

是一个非常强大的组件和ZF2基本上是一个事件驱动的框架了.

在你的

module.php

你可以添加这样的:

// Setup the Zend Logger, pseudocode
$logger = new Logger;
$writer = new Writer;
$logger->addWriter($writer);

// Attach a logging listener for the log event on application level, working code
$events = StaticEventManager::getInstance();
$events->attach('*', 'log', function($event) use ($logger) {
$target = get_class($event->getTarget());
$message = $event->getParam('message', 'No message provided');
$priority = (int) $event->getParam('priority', Logger::INFO);
$message = sprintf('%s: %s', $target, $message);
$logger->log($priority, $message);
});

然后,从任何地方,例如从一个控制器,你可以这样做:

$this->getEventManager()->trigger('log', $this, array(
'priority' => 7,
'message' => 'some log message'
));


0 0
原创粉丝点击