前言
在 Laravel 5.6 版本中日志行為可以很容易的進(jìn)行自定義,而在5.5以下版本中日志行為自定義自由度并不是很高,但是項(xiàng)目有需求不能因?yàn)檫@個(gè)就強(qiáng)行將項(xiàng)目升級(jí)為5.6吧,況且作為一個(gè)穩(wěn)定的項(xiàng)目升級(jí)框架大版本有可能會(huì)有很多坑,基于這些原因我嘗試了對(duì) Laravel 5.5 的日志進(jìn)行改造以適應(yīng)我的需求。
Laravel 的日志行為大部分是在 Illuminate\Log\LogServiceProvider 中,我們可以看一下其中的代碼片段:
/**
* Configure the Monolog handlers for the application.
*
* @param \Illuminate\Log\Writer $log
* @return void
*/
protected function configureDailyHandler(Writer $log)
{
$log->useDailyFiles(
$this->app->storagePath().'/logs/laravel.log', $this->maxFiles(),
$this->logLevel()
);
}
這是我最常在項(xiàng)目中使用的日志存儲(chǔ)方式,可以看到日志的存儲(chǔ)路徑幾近與寫死的狀態(tài),無(wú)法通過(guò)外部參數(shù)輕易的更改。
最開始我想的是重寫這個(gè) Provider 然后將其注冊(cè)到 app.php 的 providers 數(shù)組中,但是這種行為并不可行,因?yàn)橥ㄟ^(guò)查看源碼, LogServiceProvider 是在框架啟動(dòng)時(shí)就注冊(cè)。
在 中有這樣一個(gè)方法控制了這個(gè)注冊(cè)行為:
protected function registerBaseServiceProviders()
{
$this->register(new EventServiceProvider($this));
$this->register(new LogServiceProvider($this));
$this->register(new RoutingServiceProvider($this));
}
既然我們知道了它們是如何生效的,那么我們將這兩個(gè)類繼承并修改其中我們需要改變的行為進(jìn)行改造,我的改造方式如下。在 app\Providers 中新建 LogServiceProvider 類繼承 Illuminate\Log\LogServiceProvider ,代碼如下:
?php
namespace App\Providers;
use Illuminate\Log\LogServiceProvider as BaseLogServiceProvider;
use Illuminate\Log\Writer;
class LogServiceProvider extends BaseLogServiceProvider
{
/**
* Configure the Monolog handlers for the application.
*
* @param \Illuminate\Log\Writer $log
* @return void
*/
protected function configureDailyHandler(Writer $log)
{
$path = config('app.log_path');
$log->useDailyFiles(
$path, $this->maxFiles(),
$this->logLevel()
);
}
}
在 config/app.php 目錄中添加配置:
'log_path' => env('APP_LOG_PATH', storage_path('/logs/laravel.log')),
app 目錄中新建 Foundation 目錄,新建 Application 類繼承 Illuminate\Foundation\Application 類,重寫 registerBaseServiceProviders 方法。
?php
/**
* Created by PhpStorm.
* User: dongyuxiang
* Date: 2018/7/31
* Time: 16:53
*/
namespace App\Foundation;
use App\Providers\LogServiceProvider;
use Illuminate\Events\EventServiceProvider;
use Illuminate\Routing\RoutingServiceProvider;
use Illuminate\Foundation\Application as BaseApplication;
class Application extends BaseApplication
{
/**
* Register all of the base service providers.
*
* @return void
*/
protected function registerBaseServiceProviders()
{
$this->register(new EventServiceProvider($this));
$this->register(new LogServiceProvider($this));
$this->register(new RoutingServiceProvider($this));
}
}
說(shuō)是重寫其實(shí)只是將use類換從了我們自己創(chuàng)建的 LogServiceProvider 。
然后在 bootstrap\app.php 中將變量 $app 的 new 對(duì)象換成我們繼承重寫后的。
$app = new App\Foundation\Application(
realpath(__DIR__.'/../')
);
這樣我就成功的將日志路徑可以隨便定義了,而且來(lái)說(shuō)有了這次經(jīng)驗(yàn)我對(duì)于框架不符合我需求的地方可以做更進(jìn)一步的優(yōu)化以符合我的要求,而且我沒有更改框架底層的代碼,當(dāng)框架有bug修復(fù)的時(shí)候我也可以放心的進(jìn)行框架更新。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
您可能感興趣的文章:- laravel+vue組合的項(xiàng)目中引入ueditor方式(打包成組件形式)
- 在laravel中使用Symfony的Crawler組件分析HTML
- Laravel框架中擴(kuò)展函數(shù)、擴(kuò)展自定義類的方法
- PHP框架Laravel插件Pagination實(shí)現(xiàn)自定義分頁(yè)
- laravel通過(guò)創(chuàng)建自定義artisan make命令來(lái)新建類文件詳解
- Laravel中重寫資源路由自定義URL的實(shí)現(xiàn)方法
- Laravel Validator自定義錯(cuò)誤返回提示消息并在前端展示
- Laravel認(rèn)證原理以及完全自定義認(rèn)證詳解
- 關(guān)于Laravel-admin的基礎(chǔ)用法總結(jié)和自定義model詳解
- laravel框架學(xué)習(xí)筆記之組件化開發(fā)實(shí)現(xiàn)方法