ホームページ >バックエンド開発 >PHPチュートリアル >Laravel ログ保存ディレクトリの問題。
laravel的日志保存目录能不能不保存到 storage/logs 目录下?怎么修改?
可不可以自定义文件名?
按照文档配置按日期分割,不管用!还是在laravel.log 里面追加。
laravel的日志保存目录能不能不保存到 storage/logs 目录下?怎么修改?
可不可以自定义文件名?
按照文档配置按日期分割,不管用!还是在laravel.log 里面追加。
自定义日志
<code class="php">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");</code>
1、可以使用该方法对laravel原有日志覆盖【一个info,其他级别可自行扩展】
2、作为一个laravel扩展,在需要单独记录日志的地方记录;
<code class="php">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); } }</code>
重写
configureSingleHandler
就相当于重写了一个日志处理器;
修改根目录下的
composer.json
文件
<code class="json">"psr-4": { "App\\": "app/", "你自定义命名空间\\": "文件路径/" }</code>
在
/app/Http/Kernel.php
文件中,扩展Kernel
类的构造方法
<code class="php">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'; } }); }</code>
<code class="php">Log::info('自定义log处理器');</code>
创建一个ServiceProvider和facade(个人习惯喜欢使用facade);添加至app config中,使用composer自动加载即可;