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 :
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.
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' => [ // ... ],
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 :
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!