佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > Laravel5.5以下版本中如何自定義日志行為詳解

Laravel5.5以下版本中如何自定義日志行為詳解

熱門標簽:Linux服務(wù)器 科大訊飛語音識別系統(tǒng) 銀行業(yè)務(wù) Mysql連接數(shù)設(shè)置 阿里云 電子圍欄 服務(wù)器配置 團購網(wǎng)站

前言

在 Laravel 5.6 版本中日志行為可以很容易的進行自定義,而在5.5以下版本中日志行為自定義自由度并不是很高,但是項目有需求不能因為這個就強行將項目升級為5.6吧,況且作為一個穩(wěn)定的項目升級框架大版本有可能會有很多坑,基于這些原因我嘗試了對 Laravel 5.5 的日志進行改造以適應(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()
 );
}

這是我最常在項目中使用的日志存儲方式,可以看到日志的存儲路徑幾近與寫死的狀態(tài),無法通過外部參數(shù)輕易的更改。

最開始我想的是重寫這個 Provider 然后將其注冊到 app.php 的 providers 數(shù)組中,但是這種行為并不可行,因為通過查看源碼, LogServiceProvider 是在框架啟動時就注冊。

在 中有這樣一個方法控制了這個注冊行為:

protected function registerBaseServiceProviders()
{
 $this->register(new EventServiceProvider($this));

 $this->register(new LogServiceProvider($this));

 $this->register(new RoutingServiceProvider($this));
}

既然我們知道了它們是如何生效的,那么我們將這兩個類繼承并修改其中我們需要改變的行為進行改造,我的改造方式如下。在 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));
 }
}

說是重寫其實只是將use類換從了我們自己創(chuàng)建的 LogServiceProvider 。

然后在 bootstrap\app.php 中將變量 $app 的 new 對象換成我們繼承重寫后的。

$app = new App\Foundation\Application(
 realpath(__DIR__.'/../')
);

這樣我就成功的將日志路徑可以隨便定義了,而且來說有了這次經(jīng)驗我對于框架不符合我需求的地方可以做更進一步的優(yōu)化以符合我的要求,而且我沒有更改框架底層的代碼,當框架有bug修復的時候我也可以放心的進行框架更新。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • laravel+vue組合的項目中引入ueditor方式(打包成組件形式)
  • 在laravel中使用Symfony的Crawler組件分析HTML
  • Laravel框架中擴展函數(shù)、擴展自定義類的方法
  • PHP框架Laravel插件Pagination實現(xiàn)自定義分頁
  • laravel通過創(chuàng)建自定義artisan make命令來新建類文件詳解
  • Laravel中重寫資源路由自定義URL的實現(xiàn)方法
  • Laravel Validator自定義錯誤返回提示消息并在前端展示
  • Laravel認證原理以及完全自定義認證詳解
  • 關(guān)于Laravel-admin的基礎(chǔ)用法總結(jié)和自定義model詳解
  • laravel框架學習筆記之組件化開發(fā)實現(xiàn)方法

標簽:江蘇 萍鄉(xiāng) 棗莊 廣元 衢州 大理 蚌埠 衡水

巨人網(wǎng)絡(luò)通訊聲明:本文標題《Laravel5.5以下版本中如何自定義日志行為詳解》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    清河县| 塔城市| 曲阜市| 尼勒克县| 托里县| 通辽市| 七台河市| 和平区| 韶山市| 台南市| 湖南省| 扎兰屯市| 类乌齐县| 文安县| 五华县| 深泽县| 涟源市| 武宣县| 建湖县| 光山县| 成都市| 崇信县| 宁强县| 左云县| 繁峙县| 中超| 岐山县| 三原县| 鹿邑县| 南部县| 博爱县| 永泰县| 夏河县| 云安县| 紫金县| 奉节县| 武平县| 攀枝花市| 调兵山市| 凤山县| 洪洞县|