如何从index.php调用独白?

时间:2019-05-04 15:56:18

标签: php monolog php-di

有一个在PHP-DI上使用Monolog的示例(从手册中,有2个文件-index.php和config.php:

<?php
// config.php

use Monolog\Logger;
use Monolog\Handler\StreamHandler;

return [
    // ...

    Psr\Log\LoggerInterface::class => DI\factory(function () {
        $logger = new Logger('mylog');

        $fileHandler = new StreamHandler('path/to/your.log', Logger::DEBUG);
        $fileHandler->setFormatter(new LineFormatter());
        $logger->pushHandler($fileHandler);

        return $logger;
    }),
];

此config.php在以下代码中使用:

// index.php    
use DI\ContainerBuilder;

require __DIR__ . '/../vendor/autoload.php';

$containerBuilder = new ContainerBuilder;
$containerBuilder->addDefinitions(__DIR__ . '/config.php');
$container = $containerBuilder->build();

现在如何在index.php中使用它?我经常以这种方式使用Monolog:

$log = new Logger('name'); 
$log->warning('Foo');

但是如何通过Container调用它? 我能够在简单的$ container-> set(),$ container-> get()模式下完成此操作。但是以这种方式使用Container Builder,我找不到解决方法。此外,当我制作var_dump($container)时,其中没有任何记录器的标志。

1 个答案:

答案 0 :(得分:2)

您需要将$log = new Logger('name')替换为:

$log = $container->get(\Psr\Log\LoggerInterface::class);

请参阅文档的这一部分:http://php-di.org/doc/getting-started.html#3-create-the-objects