Home > PHP Framework > Laravel > laravel log writing method

laravel log writing method

WBOY
Release: 2023-05-20 17:36:08
Original
1600 people have browsed it

Laravel is a very popular PHP development framework. Its flexibility and powerful functions have been favored by the majority of developers. During the application development process, logging is a very important task, which can help developers quickly locate and solve problems. This article will introduce how to write logs in Laravel.

  1. Configuring log information

The log configuration information in Laravel is stored in the logging.php file in the config directory. The default log driver and Log channel are defined in this file.

You can customize the log driver and Log channel as needed. The most common types of log drivers include: single file and daily log files. Among them, the single file mode records all logs to one file, while the daily log file mode creates a new log file based on each day's date.

After selecting the log driver type in the configuration file, we also need to configure the Log channel for use when recording logs in the application.

  1. Use Log Facade to write logs

Laravel provides a Log Facade, which provides a method for recording logs, allowing us to easily record log information into a log file. . Directly use Log:: to call Log Facade, and use info() or debug() to record log information. As shown below:

use IlluminateSupportFacadesLog;

// 记录 Info 级别的日志信息
Log::info('This is an info level message.');

// 记录 Debug 级别的日志信息
Log::debug('This is a debug level message.');
Copy after login

You can define different Log channels in the log configuration file and set different handlers (Handlers) to store log information in different locations.

As shown below:

use IlluminateSupportFacadesLog;

// 使用 MyLog 通道记录 Info 级别的日志信息
Log::channel('MyLog')->info('This is an info level message.');

// 使用 MyLog 通道记录 Debug 级别的日志信息
Log::channel('MyLog')->debug('This is a debug level message.');
Copy after login
  1. Use Monolog to write logs

Monolog is a powerful logging tool in PHP, Laravel uses Monolog as its Log component. Monolog provides a variety of processors and formatters, allowing us to configure logs in more detail.

In Laravel, we can use Monolog to process and record log information. Laravel implements Monolog encapsulation through container binding. We can customize Monolog instances through container binding and name each instance so that we can reference it in our application.

As shown below, we can bind a new Monolog instance in AppServiceProvider:

use MonologLogger;
use MonologHandlerStreamHandler;

public function register()
{
    $this->app->bind('myLogger', function () {
        $log = new Logger('myLog');
        $log->pushHandler(new StreamHandler(storage_path('logs/myLog.log')), Logger::INFO);
        return $log;
    });
}
Copy after login

Then, use this instance to record log information in the application. As shown below:

use IlluminateSupportFacadesLog;

Log::channel('myLogger')->info('This is an info level message.');
Copy after login

In addition to using the default log configuration file, we can also use a custom log configuration file to configure Monolog. As shown below, use Monolog's addRecord() method in the custom log configuration file to add log information:

use MonologLogger;

return [
    'myLog' => [
        'driver' => 'monolog',
        'level' => 'debug',
        'handler_with' => [
            [
                'handler' => StreamHandler::class,
                'options' => [
                    'level' => Logger::INFO,
                    'stream' => storage_path('logs/mylog.log'),
                    'bubble' => true
                ]
            ]
        ],
        'tap' => [MyLogChannel::class]
    ]
];
Copy after login

It should be noted that the tap configuration here is automatic Define Log channel instance. We must register the instance with the application so that it can be used to record logging information.

  1. Summary

In Laravel, logging is a necessary task for application development. By configuring the log configuration file and using Log Facade and Monolog, we can easily record log information and process it.

Of course, here we only introduce the most basic method of writing logs in Laravel. If you need a more in-depth understanding, you can check the official Laravel documentation or search for relevant information.

The above is the detailed content of laravel log writing method. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template