Maison >cadre php >Laravel >Pourquoi le journal généré par Laravel n'a-t-il aucune autorisation ?

Pourquoi le journal généré par Laravel n'a-t-il aucune autorisation ?

PHPz
PHPzoriginal
2023-04-12 09:13:41760parcourir

Laravel est un framework PHP largement utilisé qui fournit des fonctions et des outils riches pour permettre aux développeurs de créer rapidement des applications Web sécurisées, fiables et faciles à entretenir. La fonction de journalisation intégrée de Laravel permet aux développeurs d'enregistrer les journaux d'exécution des applications dans des fichiers à des fins d'analyse et de dépannage. Cependant, dans certains cas, les fichiers journaux générés par Laravel peuvent rencontrer des problèmes d'autorisation et ne pas s'afficher correctement.

La raison pour laquelle Laravel génère des fichiers journaux sans autorisation est que les autorisations de l'emplacement de stockage des fichiers sont insuffisantes. Afin de résoudre ce problème, nous pouvons utiliser les méthodes suivantes :

  1. Ajuster les autorisations de l'emplacement de stockage

Par défaut, les fichiers journaux Laravel sont stockés dans le répertoire storage/logs. Nous devons nous assurer que les autorisations sur le répertoire sont suffisantes pour permettre au processus PHP d'écrire et de lire à partir du répertoire. Vous pouvez exécuter la commande suivante dans le terminal pour définir les autorisations du répertoire :

chmod -R 775 storage/logs

Le paramètre d'autorisation 775 permet au propriétaire et aux utilisateurs du groupe de lire, d'écrire et d'exécuter le répertoire, et les autres utilisateurs ne peuvent que lire et exécuter.

  1. Modifier l'emplacement de stockage des journaux Laravel

Si nous ne souhaitons pas utiliser l'emplacement de stockage par défaut, nous pouvons modifier l'emplacement de stockage via le fichier de configuration. Ouvrez le fichier config/logging.php, recherchez l'option de chemin dans le journal et modifiez-la avec le chemin de stockage spécifié.

'log' => env('APP_LOG', 'single'),
    'path' => '/your/folder/path/logs/laravel.log',
    'level' => env('LOG_LEVEL', 'debug'),
    'channels' => [
        // ...
    ],
  1. Capturez les journaux Laravel et stockez-les dans la base de données

Nous pouvons capturer et stocker les journaux Laravel dans la base de données au lieu de fichiers. Cette méthode peut éviter les problèmes d'autorisation de fichiers et faciliter l'analyse des journaux et les statistiques.

Nous devons effectuer les opérations suivantes :

  • Créer une table de journal dans la base de données pour stocker les données du journal ;
  • Enregistrer l'implémentation de l'interface de journal dans le fichier app/Providers/AppServiceProvider.php ; logging. Configuration dans le fichier php, définissez l’option de journalisation sur base de données.
  • La première étape, créez une table de journal
CREATE TABLE `logs` (
    `id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT,
    `channel` varchar(255) COLLATE utf8mb4_unicode_ci NOT NULL,
    `level` varchar(255) COLLATE utf8mb4_unicode_ci NOT NULL,
    `message` text COLLATE utf8mb4_unicode_ci NOT NULL,
    `context` text COLLATE utf8mb4_unicode_ci NOT NULL,
    `extra` text COLLATE utf8mb4_unicode_ci NOT NULL,
    `created_at` datetime(6) NOT NULL,
    PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;

La deuxième étape, enregistrez l'AppServiceProvider

Ajoutez le code suivant dans le fichier app/Providers/AppServiceProvider.php :

use Illuminate\Support\Facades\Log;
use Monolog\Handler\StreamHandler;
use Monolog\Logger;

public function boot()
{
    $logger = new Logger('laravel');
    $logger->pushHandler(new StreamHandler(storage_path('logs/laravel.log'), Logger::DEBUG));

    Log::listen(function ($level, $message, $context) use ($logger) {
        $logger->$level($message, $context);
    });
}

La troisième étape, modifiez la configuration/logging .php

Modifiez de la même manière la configuration dans le fichier config/logging.php et définissez l'option de journalisation sur base de données :

'log' => 'database',
'channels' => [
        // ...
    ],

Les trois méthodes ci-dessus peuvent aider les développeurs à résoudre le problème de l'absence d'autorisations pour les fichiers journaux générés par Laravel, et le La troisième méthode peut également permettre aux développeurs de mieux gérer et analyser les informations du journal des applications.

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!

Déclaration:
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