婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Laravel 重寫日志,讓日志更優雅

Laravel 重寫日志,讓日志更優雅

熱門標簽:常州地圖標注服務商 新河科技智能外呼系統怎么樣 福州人工外呼系統哪家強 釘釘打卡地圖標注 地圖標注平臺怎么給錢注冊 百度商鋪地圖標注 注冊400電話申請 安裝電銷外呼系統 衡水外呼系統平臺

更改目的:

  • 重寫了日志格式
  • 加入trace,一次請求的唯一標識
  • 加入error級別信息推送,事例中使用企業微信群助手
  • 讓我們可以更及時、更優雅、更方便追蹤日志信息
  • 有助于初學者了解Laravel框架

1。將文件 AppTool.phpLogger.phpLogServiceProvider.php復制到 app/Providers文件夾下,將文件BaseCommand.php復制到App\Console

2 。在config/app.php→providers中加入

'providers' => [
 ……
 // 注冊日志
  App\Providers\LogServiceProvider::class
 ……
 ];

3。在項目中使用如下方式調用

// php-fpm方式調用 日志路徑 /opt/logs/xxx.log /opt/logs/xxx.error
\Log::info("info");
\Log::debug("debug");
\Log::error("error");
// 在cli方式調用 日志路徑 /opt/clogs/xxx.log /opt/clogs/xxx.error
app('cLog')->info("info");
app('cLog')->debug("debug");
app('cLog')->error("error");

4。在日志級別為error時,會執行推送,本事例中采用企業微信群推送

  /**
   * 推送錯誤信息
   * @param $message
   */
  public function pushErrorMessage($message)
  {
    $content = "app:". static::getAppName() ." 
src: ". static::getRequestSource() ."
trace:". self::getTrace() ."
url:". static::$uri_info ." 
error: ". $message ."
time:". date("Y-m-d H:i:s");
    // 測試群
    $url = "xxxxxxxxxxxx";
    $result = app('\GuzzleHttp\Client')->request('POST', $url, [
      \GuzzleHttp\RequestOptions::JSON=>[
        "msgtype"=> "text",
        "text"=> [
          "content" => $content
        ]
      ]
    ]);
    $body = \GuzzleHttp\json_decode($result->getBody()->getContents(), true);
  }

5 。日志內容

注意事項:

修改如下代碼不同版本bind部分會有所不同,具體根據\Illuminate\Foundation\Application::registerCoreContainerAliaseslog信息修改。
如laravel6.x中為'log' => [\Illuminate\Log\LogManager::class, \Psr\Log\LoggerInterface::class],

修改方式就如下方代碼

    ……
    // 注入全局容器
    $app->instance('Log', $logger);
    $app->bind('Psr\Log\LoggerInterface', function (Application $app) {
      return $app['log']->getLogger();
    });
    $app->bind('\Illuminate\Log\LogManager', function (Application $app) {
      return $app['log'];
    });
    ……
有關console中使用時,建議重寫\Illuminate\Console\Command::info\Illuminate\Console\Command::line\Illuminate\Console\Command::error,然后所有console繼承BaseCommand
demo代碼塊:
use App\Console\BaseCommand;

class Demo extends BaseCommand
{
  protected $signature = 'command:demo';
  protected $description = 'demo';
  public function __construct()
  {
    parent::__construct();
  }
  public function handle()
  {
    $this->info('this is info!');
    $this->line('this is line!');
    $this->error('this is error!!!');
  }
}

demo 命令行輸出:

到此這篇關于Laravel 重寫日志,讓日志更優雅的文章就介紹到這了,更多相關Laravel 重寫日志內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Laravel的加密解密與哈希實例講解
  • Laravel 數據庫加密及數據庫表前綴配置方法
  • laravel 5.3中自定義加密服務的方案詳解
  • Laravel中10個有用的用法小結
  • Laravel中的where高級使用方法實例講解
  • laravel使用組件實現微信網頁授權登入
  • Laravel統一封裝接口返回狀態實例講解
  • 淺談Laravel中如何對大文件進行加密

標簽:鷹潭 白城 遼陽 鶴崗 六安 唐山 柳州 克拉瑪依

巨人網絡通訊聲明:本文標題《Laravel 重寫日志,讓日志更優雅》,本文關鍵詞  Laravel,重寫,日志,讓,更,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Laravel 重寫日志,讓日志更優雅》相關的同類信息!
  • 本頁收集關于Laravel 重寫日志,讓日志更優雅的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 阳谷县| 海丰县| 宁远县| 玉门市| 信宜市| 庆城县| 通许县| 梁平县| 临海市| 唐山市| 昌图县| 灵山县| 连江县| 贵阳市| 全南县| 科尔| 梅河口市| 南溪县| 井陉县| 来安县| 涟水县| 湖州市| 城口县| 汾西县| 香港| 康马县| 娱乐| 牙克石市| 宁德市| 湘阴县| 凤台县| 永嘉县| 永丰县| 青铜峡市| 承德县| 华安县| 康平县| 武邑县| 宁化县| 普兰店市| 临汾市|