欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2018年08月01日 11:49:43   作者:麥索  
這篇文章主要給大家介紹了關(guān)于Laravel5.5以下版本中如何自定義日志行為的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

前言

在 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修復(fù)的時候我也可以放心的進行框架更新。

總結(jié)

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

相關(guān)文章

  • 一個簡單安全的PHP驗證碼類、PHP驗證碼

    一個簡單安全的PHP驗證碼類、PHP驗證碼

    這篇文章主要介紹了一個簡單安全的PHP驗證碼類 PHP驗證碼的相關(guān)資料,需要的朋友可以參考下
    2016-09-09
  • Laravel框架視圖和模型操作方法分析

    Laravel框架視圖和模型操作方法分析

    這篇文章主要介紹了Laravel框架視圖和模型操作方法,結(jié)合實例形式詳細分析了laravel框架視圖和模型的概念、原理、創(chuàng)建及使用方法,需要的朋友可以參考下
    2019-12-12
  • 詳解Laravel視圖間共享數(shù)據(jù)與視圖Composer

    詳解Laravel視圖間共享數(shù)據(jù)與視圖Composer

    視圖的基本使用很簡單,可查看視圖文檔了解詳情,今天這里我們演示兩個使用示例:在視圖間共享數(shù)據(jù)和視圖Composer。下面一起來看看。
    2016-08-08
  • thinkPHP5項目中實現(xiàn)QQ第三方登錄功能

    thinkPHP5項目中實現(xiàn)QQ第三方登錄功能

    這篇文章主要介紹了thinkPHP5項目中實現(xiàn)QQ第三方登錄功能,結(jié)合實例形式較為詳細的分析了修改QQ登陸接口并整合進thinkPHP5項目中的具體步驟與相關(guān)操作技巧,需要的朋友可以參考下
    2017-10-10
  • 深入解析Laravel5.5中的包自動發(fā)現(xiàn)Package Auto Discovery

    深入解析Laravel5.5中的包自動發(fā)現(xiàn)Package Auto Discovery

    眾所周知Laravel 5.5 發(fā)布在即,目前已經(jīng)確定會增加一個神奇的新特性:Package Auto Discovery。下面這篇文章主要給大家深入的介紹了關(guān)于Laravel5.5中包自動發(fā)現(xiàn)Package Auto Discovery的相關(guān)資料,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-09-09
  • PHP的Yii框架中使用數(shù)據(jù)庫的配置和SQL操作實例教程

    PHP的Yii框架中使用數(shù)據(jù)庫的配置和SQL操作實例教程

    這篇文章主要介紹了PHP的Yii框架中使用數(shù)據(jù)庫的配置和SQL操作實例教程,Yii支持綁定多種數(shù)據(jù)庫,文中主要對各種查詢語句在Yii中的使用給出了例子,需要的朋友可以參考下
    2016-03-03
  • php微信公眾號開發(fā)之簡答題

    php微信公眾號開發(fā)之簡答題

    這篇文章主要為大家詳細介紹了php微信公眾號開發(fā)之簡答題,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-10-10
  • php將gd生成的圖片緩存到memcache的小例子

    php將gd生成的圖片緩存到memcache的小例子

    php將gd生成的圖片緩存到memcache的小例子,需要的朋友可以參考一下
    2013-06-06
  • Ubuntu 16.04中Laravel5.4升級到5.6的步驟

    Ubuntu 16.04中Laravel5.4升級到5.6的步驟

    這篇文章主要給大家介紹了關(guān)于在Ubuntu 16.04中Laravel5.4升級到5.6的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-12-12
  • PHP實現(xiàn)的簡單留言板功能示例【基于thinkPHP框架】

    PHP實現(xiàn)的簡單留言板功能示例【基于thinkPHP框架】

    這篇文章主要介紹了PHP實現(xiàn)的簡單留言板功能,結(jié)合實例形式分析了基于thinkPHP框架實現(xiàn)的留言板相關(guān)配置、數(shù)據(jù)庫操作、sql語句等實現(xiàn)技巧與操作注意事項,需要的朋友可以參考下
    2018-12-12

最新評論