Maison > cadre php > Laravel > Comment enregistrer des journaux dans le framework Laravel

Comment enregistrer des journaux dans le framework Laravel

PHPz
Libérer: 2023-04-11 15:40:27
original
1571 Les gens l'ont consulté

Avec le développement de la technologie Internet, de plus en plus de personnes s'intéressent aux problèmes de performances et de sécurité des applications Web. Dans ce cas, la journalisation devient de plus en plus importante dans les applications Web. La journalisation est un outil très utile pour nous aider à suivre et déboguer les applications. La journalisation peut nous aider à mieux comprendre le fonctionnement de l'application et nous aider à trouver des pannes et à résoudre des problèmes en cas de panne de l'application.

Laravel est un framework PHP populaire doté de nombreuses fonctionnalités utiles, notamment des capacités de journalisation. Dans cet article, nous verrons comment se connecter au framework Laravel.

Connexion dans le framework Laravel

La connexion dans le framework Laravel peut aider les développeurs à enregistrer des événements, des erreurs, des exceptions et d'autres informations dans les applications. Le framework Laravel fournit un système de journalisation flexible pour enregistrer différents types d'informations dans votre application. La journalisation nous aide à comprendre l'état de santé, les problèmes et les exceptions de l'application, ce qui est très important pour la maintenance de l'application.

La journalisation dans le framework Laravel est divisée en deux types : les journaux système et les journaux d'application. Le journal système enregistre des informations sur le fonctionnement de l'application elle-même, telles que le système d'exploitation utilisé par le serveur, la version PHP, la version Laravel, etc. Les journaux d'application enregistrent des informations plus détaillées sur l'application, telles que des informations sur les demandes des utilisateurs, des informations sur les erreurs et les exceptions, etc.

Dans le framework Laravel, la journalisation est implémentée via une API unifiée. Cette API nous permet de consigner des informations à tout moment sans nous soucier de savoir où et comment se connecter. Le framework Laravel prend en charge une variété de pilotes de journaux différents, notamment File, Monolog, Syslog, ErrorLog, Slack, etc. Nous pouvons choisir quel pilote utiliser via les options du fichier de configuration.

Niveaux de journalisation dans le framework Laravel

Le framework Laravel fournit six niveaux de journalisation différents, nous permettant d'ajuster le détail de la génération de journaux en fonction de différents types d'événements d'application. Ces niveaux de journal incluent:

  • égency
  • aert
  • critical
  • error
  • warning
  • notice
  • info
  • débogage (débogage)

Each se voient une priorité numérique différente pour contrôler la fréquence de l'enregistrement enregistrer les informations. Par exemple, lorsque le niveau de journalisation est défini sur Urgence, les informations du journal ne seront enregistrées qu'en cas de panne grave du système. Lorsque le niveau est défini sur débogage, toutes les informations, y compris les informations de débogage les plus détaillées, sont enregistrées.

Connexion à Laravel Framework

La connexion à Laravel Framework est très simple. Nous n'avons besoin que d'utiliser les méthodes de la classe de façade Log pour enregistrer les informations. Comme indiqué ci-dessous : Logfacade类中的方法来记录信息即可。如下所示:

use Illuminate\Support\Facades\Log;

//记录一个info级别的信息
Log::info('这是一个信息。');

//记录一个warning级别的信息
Log::warning('这是一个警告。');

//记录一个error级别的信息
Log::error('这是一个错误。');
Copier après la connexion

我们还可以在记录日志时传递更多的数据,例如:用户的请求信息、异常信息等等。这些信息可以帮助我们更好地了解应用程序的运行情况,并发现和解决潜在的问题。

use Illuminate\Support\Facades\Log;

$user = ‘Adam’; //获取当前用户
$url = 'http://www.test.tk'; //获取用户访问的URL

//记录一个info级别的信息,并传递用户名和URL
Log::info('用户访问了一个URL', ['user' => $user, 'url' => $url]);

try {
    //执行业务逻辑代码
} catch (Exception $e) {
    //记录异常信息,并传递异常信息对象
    Log::error('发生一个异常', ['exception' => $e]);
}
Copier après la connexion

在Laravel框架中配置日志

Laravel框架的日志配置非常灵活,我们可以通过配置文件或代码来控制日志记录的行为。下面是一个典型的config/logging.php

return [
    'default' => env('LOG_CHANNEL', 'stack'),
    'channels' => [
        'stack' => [
            'driver' => 'stack',
            'channels' => ['daily','slack'], //使用两个驱动程序:daily和slack
            'expires' => 14,
        ],

        'daily' => [
            'driver' => 'daily',
            'path' => storage_path('/logs/laravel.log'),
            'level' => 'info',
            'days' => 14,
        ],

        'slack' => [
            'driver' => 'slack',
            'url' => env('LOG_SLACK_WEBHOOK_URL'),
            'username' => 'Laravel Log', 
            'emoji' => ':boom:',
            'level' => 'critical',
        ],
    ],
];
Copier après la connexion
Nous pouvons également transmettre davantage de données lors de l'enregistrement des journaux, telles que des informations sur les demandes des utilisateurs, des informations sur les exceptions, etc. Ces informations peuvent nous aider à mieux comprendre le fonctionnement de l'application et à identifier et résoudre les problèmes potentiels.

rrreee

Configuration des journaux dans le framework Laravel

La configuration des journaux du framework Laravel est très flexible et nous pouvons contrôler le comportement de la journalisation via des fichiers de configuration ou du code. Voici un exemple de configuration typique du fichier config/logging.php :

rrreee

Dans ce fichier de configuration, nous définissons deux types de pilotes : daily et slack. Le pilote quotidien utilise un fichier journal rotatif quotidien pour enregistrer les informations du journal, tandis que le pilote Slack envoie les informations du journal à un canal Slack afin que les membres de l'équipe puissent comprendre instantanément l'état d'exécution de l'application.

Résumé🎜🎜La fonction de journalisation du framework Laravel peut nous aider à mieux comprendre l'état d'exécution et les problèmes de l'application. À l'aide de l'API de journalisation du framework Laravel, nous pouvons facilement enregistrer différents types d'informations, notamment les informations d'exception, les informations d'erreur, les informations d'avertissement, les informations de débogage, etc. Dans le même temps, en utilisant différents pilotes, nous pouvons choisir différentes méthodes de stockage des journaux, telles que des fichiers, des bases de données, Slack, etc., pour répondre aux besoins de différents scénarios d'application. 🎜🎜Dans le développement actuel, la journalisation des applications devrait être un maillon très important. Les développeurs doivent choisir le niveau de journalisation et la méthode de stockage des journaux appropriés en fonction des besoins et des conditions de l'application afin de mieux comprendre le fonctionnement de l'application. 🎜

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal