3

有使用 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),其中没有任何记录器的迹象。

4

1 回答 1

2

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

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

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

于 2019-05-04T16:22:05.997 回答