>백엔드 개발 >PHP 튜토리얼 >Laravel 로그 사용 정보

Laravel 로그 사용 정보

不言
不言원래의
2018-06-13 15:26:152378검색

이 글은 주로 라라벨 로그의 사용법을 소개하고, 라라벨 로그의 기능, 정의, 사용방법, 관련 주의사항 등을 예시 형태로 자세히 분석해 놓은 글입니다. 도움이 필요한 친구들이 참고할 수 있습니다

이 글에서는 라라벨 로그의 사용법을 설명합니다. 예제가 포함된 로그입니다. 참고할 수 있도록 모든 사람과 공유하세요. 세부 사항은 다음과 같습니다.

여기에 사용된 Laravel 버전은 여전히 ​​5.2입니다.

로그는 매우 중요합니다. 로컬 개발을 위해 디버그 모드를 켤 수 있지만 온라인 프로젝트의 로그를 보는 것은 매우 간단하고 효과적인 디버깅 방법입니다. Laravel은 Monolog 로깅 라이브러리를 통합하여 다양하고 강력한 로그 프로세서를 제공합니다.

Laravel은 단일, 일일, syslog 및 오류 로그 로깅 방법을 지원합니다. 예를 들어 단일 파일을 생성하지 않고 매일 로그 파일을 생성하려면 구성 파일 config/app.php에서 로그 값을 다음과 같이 설정해야 합니다.

'log' => 'daily'

시스템 기본값 구성은 단일입니다

#config/app.php:111
'log' => env('APP_LOG', 'single'),

라라벨이 로그를 어떻게 구성하는지 살펴보겠습니다.

#vendor/laravel/framework/src/Illuminate/Foundation/Http/Kernel.php:36
protected $bootstrappers = [
    'Illuminate\Foundation\Bootstrap\DetectEnvironment',
    'Illuminate\Foundation\Bootstrap\LoadConfiguration',
    'Illuminate\Foundation\Bootstrap\ConfigureLogging',
    'Illuminate\Foundation\Bootstrap\HandleExceptions',
    'Illuminate\Foundation\Bootstrap\RegisterFacades',
    'Illuminate\Foundation\Bootstrap\RegisterProviders',
    'Illuminate\Foundation\Bootstrap\BootProviders',
];
<?php
namespace Illuminate\Foundation\Bootstrap;
use Illuminate\Log\Writer;
use Monolog\Logger as Monolog;
use Illuminate\Contracts\Foundation\Application;
class ConfigureLogging
{
/**
 * Bootstrap the given application.
 *
 * @param \Illuminate\Contracts\Foundation\Application $app
 * @return void
 */
public function bootstrap(Application $app)
{
  $log = $this->registerLogger($app);
  // If a custom Monolog configurator has been registered for the application
  // we will call that, passing Monolog along. Otherwise, we will grab the
  // the configurations for the log system and use it for configuration.
  if ($app->hasMonologConfigurator()) {
    call_user_func(
      $app->getMonologConfigurator(), $log->getMonolog()
    );
  } else {
    $this->configureHandlers($app, $log);
  }
}

Monlog 구성을 맞춤 설정하는 경우 if 조건을 사용하고 else를 기본값으로 설정하세요

protected function configureHandlers(Application $app, Writer $log)
{
    $method = &#39;configure&#39;.ucfirst($app[&#39;config&#39;][&#39;app.log&#39;]).&#39;Handler&#39;;
    $this->{$method}($app, $log);
}
/**
* Configure the Monolog handlers for the application.
*
* @param \Illuminate\Contracts\Foundation\Application $app
* @param \Illuminate\Log\Writer $log
* @return void
*/
protected function configureSingleHandler(Application $app, Writer $log)
{
     $log->useFiles(
       $app->storagePath().&#39;/logs/laravel.log&#39;, #存储文件
       $app->make(&#39;config&#39;)->get(&#39;app.log_level&#39;, &#39;debug&#39;) #存储级别
     );
}

여기서 useFiles 메소드는 signle 파일 로그 핸들러를 등록하고 저장 파일 및 저장 수준을 설정하는 것입니다.

로그 초기화 시 로그 처리 등록 방법은 4가지 입니다.

public function useFiles($path, $level = &#39;debug&#39;) #单一文件
public function useDailyFiles($path, $days = 0, $level = &#39;debug&#39;) #每日生成
public function useSyslog($name = &#39;laravel&#39;, $level = &#39;debug&#39;) #系统日志的方式
public function useErrorLog($level = &#39;debug&#39;, $messageType = ErrorLogHandler::OPERATING_SYSTEM) #等同于php的error_log方式

로그 초기화 정보는 기본적으로 위와 같습니다.

로그 파사드를 사용하여 로그에 로그 정보를 쓸 수 있습니다:

8가지 로그 수준: 비상, 경고, 심각, 오류, 경고, 알림, 정보 및 디버그.

Log::emergency($error);
Log::alert($error);
Log::critical($error);
Log::error($error);
Log::warning($error);
Log::notice($error);
Log::info($error);
Log::debug($error);

이상은 이 글의 전체 내용입니다. 더 많은 관련 내용은 PHP 중국어 홈페이지를 주목해주세요!

관련 권장사항:

Laravel5의 쿠키 사용에 대하여

laravel 모델 이벤트의 여러 사용법을 알아보세요

위 내용은 Laravel 로그 사용 정보의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.