如何为Zend Framework MVC应用程序配置默认的ZendLog工厂?

时间:2017-02-26 23:51:30

标签: zend-framework-mvc zend-framework3 zend-log

我有ZendFramework application。它运行的Zend Framework 3.我添加了zend-log,并将其注入constructor of the IndexController我在索引控制器的索引操作中记录一条消息,如此。

public function __construct(Logger $logger) 
{
    $this->logger = $logger;
}

public function indexAction()
{
    $this->logger->info('Example Log Message');
    return new ViewModel();
}

我能够使用vendor/bin/generate-factory-for-class为此生成工厂。我把它添加到模块配置中就像这样。

'controllers' => [
    'factories' => [
        Controller\IndexController::class => Controller\IndexControllerFactory::class,
    ],
],

当我运行索引控制器时,我收到以下错误:

/var/www/vendor/zendframework/zend-log/src/Logger.php:434
No log writer specified

我知道我可以添加以下作者:

$logger->addWriter($writer);

我的问题是配置记录器的位置在哪里?我只是将它添加到模块配置中的['service_manager' => 'factories' => [ . . . ] ]吗?我应该把我写的工厂课程放在哪里?与其他服务?

我正在努力以“正确”的方式解决这个问题。

1 个答案:

答案 0 :(得分:1)

通常,记录器配置保存在module.config.php中。但可以肯定的是,它可以位于其他地方。没有正确的方法,但不知道你想要实现的目标,我建议你遵循传统。

添加到您的module.config.php

'service_manager' => [
    'factories' => [
        'log' => \Zend\Log\LoggerServiceFactory::class,
    ],
],

'log' => [
    'writers' => [
        [
            'name' => 'stream',
            'options' => [
                'stream' => "test.log"
            ]
        ]
    ]
]

您的控制器工厂可能如下所示:

class IndexControllerFactory implements FactoryInterface
{
    public function __invoke (ContainerInterface $container, $requestedName, array $options = null)
    {
        $indexController = new IndexController();
        $indexController->setLogger ($container->get ('log'));

        return $indexController;
    }
}

和控制器本身:

use Zend\Log\LoggerAwareInterface;
use Zend\Log\LoggerAwareTrait;
use Zend\Mvc\Controller\AbstractActionController;
use Zend\View\Model\ViewModel;

class IndexController extends AbstractActionController implements LoggerAwareInterface
{
    use LoggerAwareTrait;

    public function testAction ()
    {
        $this->logger->info("test");
    }
}