欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

laravel 日志保存目录问题;

程序员文章站 2022-06-11 10:30:09
...

laravel的日志保存目录能不能不保存到 storage/logs 目录下?怎么修改?
可不可以自定义文件名?
按照文档配置按日期分割,不管用!还是在laravel.log 里面追加。

laravel 日志保存目录问题;

回复内容:

laravel的日志保存目录能不能不保存到 storage/logs 目录下?怎么修改?
可不可以自定义文件名?
按照文档配置按日期分割,不管用!还是在laravel.log 里面追加。

laravel 日志保存目录问题;

自定义日志

Method 1->简单粗暴

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

$log = new Logger('vikin');

$log->pushHandler(
    new StreamHandler(
        storage_path('logs/vikin.log'), 
        Logger::INFO
    )
);

$log->addInfo("test");

Method2->基于ConfigureLogging基类

1、可以使用该方法对laravel原有日志覆盖【一个info,其他级别可自行扩展】

2、作为一个laravel扩展,在需要单独记录日志的地方记录;

1、创建一个类,继承自ConfigureLogging
namespace 你自定义命名空间\ConfigureLogging;

use Illuminate\Foundation\Bootstrap\ConfigureLogging as BaseConfigureLogging;
use Monolog\Formatter\LineFormatter;
use Monolog\Handler\StreamHandler;
use Monolog\Logger;

class CustomLog extends BaseConfigureLogging
{
    protected function configureSingleHandler(Application $app, Writer $log)
    {
        // 同方法1一样, 设置日志路径、设置日志级别
        $path = storage_path('logs/vikin.log');
        $level = Logger::INFO;
        $logStreamHandler = new StreamHandler($path, $level);

        // 日志格式:使用laravel原有格式:
        // the default output format is "[%datetime%] %channel%.%level_name%: %message% %context% %extra%\n"
        $format = "[%datetime%] %channel%.%level_name%: %message% %context% %extra%\n";
        $formatter = new LineFormatter($format);
        $logStreamHandler->setFormatter($formatter);

        // 输出日志
        $logger = $log->getMonolog();
        $logger->pushHandler($logStreamHandler);
    }
}

重写configureSingleHandler就相当于重写了一个日志处理器;

3、自动加载

修改根目录下的composer.json文件

"psr-4": {
    "App\\": "app/",
    "你自定义命名空间\\": "文件路径/"
}
4、覆盖

/app/Http/Kernel.php文件中,扩展Kernel类的构造方法

use Illuminate\Contracts\Foundation\Application;
use Illuminate\Contracts\Events\Dispatcher;

public function __construct(Application $app, Dispatcher $events)
{
    parent::__construct($app, $events);

    array_walk($this->bootstrappers, function(&$bootstrapper)
    {
        if($bootstrapper === 'Illuminate\Foundation\Bootstrap\ConfigureLogging')
        {
            //替换为我们自定义的日志处理器
            $bootstrapper = '你自定义命名空间\ConfigureLogging';
        }
    });
}
5、使用
Log::info('自定义log处理器');
6、扩展

创建一个ServiceProvider和facade(个人习惯喜欢使用facade);添加至app config中,使用composer自动加载即可;

相关标签: laravel php