Conseils de gestion des erreurs PHP 7 : Comment utiliser la fonction set_error_handler pour enregistrer les erreurs dans un fichier journal

PHPz
Libérer: 2023-08-01 20:44:01
original
1118 Les gens l'ont consulté

Compétences en matière de gestion des erreurs PHP 7 : Comment utiliser la fonction set_error_handler pour enregistrer les erreurs dans un fichier journal

Pendant le processus de développement, il est très important de capturer et d'enregistrer avec précision les erreurs. PHP fournit une variété de mécanismes de gestion des erreurs, dont l'un consiste à utiliser la fonction set_error_handler pour personnaliser le gestionnaire d'erreurs. Cet article explique comment utiliser la fonction set_error_handler pour enregistrer les erreurs PHP dans un fichier journal afin que nous puissions mieux suivre et résoudre les problèmes.

1. Introduction à la fonction set_error_handler
La fonction set_error_handler est utilisée pour définir les fonctions de gestion des erreurs définies par l'utilisateur. Cette fonction est appelée lorsque PHP rencontre une erreur, en lui transmettant les informations d'erreur en paramètre. Nous pouvons personnaliser le processus de gestion des erreurs grâce à cette fonction.

Ce qui suit est la syntaxe de base de la fonction set_error_handler :

bool set_error_handler ( callable $error_handler [, int $error_types = E_ALL | E_STRICT ] )

Parmi eux, le paramètre $error_handler est une fonction de gestion des erreurs appelable. De plus, le paramètre $error_types est un paramètre facultatif utilisé pour spécifier le type d'erreur. S'il n'est pas spécifié, la valeur par défaut E_ALL | E_STRICT sera utilisée, c'est-à-dire que toutes les erreurs strictes seront traitées.

2. Étapes pour enregistrer les erreurs dans un fichier journal

  1. Créer un fichier journal
    Tout d'abord, nous devons créer un fichier journal pour stocker les informations sur les erreurs. Vous pouvez nommer le fichier journal « error.log » ou tout autre nom de votre choix.
  2. Créer une fonction de gestion des erreurs personnalisée
    Ensuite, nous devons créer une fonction de gestion des erreurs personnalisée pour écrire les informations d'erreur dans le fichier journal. Voici un exemple de fonction de gestion des erreurs :

function custom_error_handler($error_number, $error_message, $error_file, $error_line) {

// 将错误信息写入日志文件
$log_message = "[" . date('Y-m-d H:i:s') . "] " . "Error: " . $error_message . " in " . $error_file . " on line " . $error_line . "
Copier après la connexion
Copier après la connexion

";

error_log($log_message, 3, 'error.log');
Copier après la connexion
Copier après la connexion

}

Dans cet exemple, nous allons Le fichier et le numéro de ligne d'erreur sont combinés dans un message de journal et la fonction error_log est utilisée pour écrire le message dans le fichier journal

  1. Définissez une fonction de gestion des erreurs personnalisée à l'aide de la fonction set_error_handler
    Enfin, nous utiliserons la fonction set_error_handler pour définir la fonction de gestion des erreurs personnalisée. . Définir comme gestionnaire d'erreurs global. Cette fonction doit être utilisée partout où les erreurs doivent être capturées dans toute l'application. Appelez simplement la fonction set_error_handler à l'entrée du programme principal, comme indiqué ci-dessous :
set_error_handler('custom_error_handler' );

Maintenant, lorsque PHP rencontre une erreur, il appellera la fonction custom_error_handler que nous avons définie et lui transmettra les informations d'erreur. Ensuite, les informations d'erreur seront écrites dans le fichier journal

3. Un exemple de code complet qui montre comment utiliser la fonction set_error_handler pour enregistrer les erreurs dans un fichier journal :

// Créer une fonction de gestion des erreurs personnalisée
function custom_error_handler($error_number, $error_message, $error_file, $error_line ) {

// 将错误信息写入日志文件
$log_message = "[" . date('Y-m-d H:i:s') . "] " . "Error: " . $error_message . " in " . $error_file . " on line " . $error_line . "
Copier après la connexion
Copier après la connexion

";

error_log($log_message, 3, 'error.log');
Copier après la connexion
Copier après la connexion

}

//Définir une fonction de gestion des erreurs personnalisée

set_error_handler('custom_error_handler');

// Déclencher délibérément une erreur

echo $undefined_variable;

// Tester la gestion des erreurs

trigger_error("Ceci est une erreur de test", E_USER_NOTICE);
?>

Dans le code ci-dessus, nous avons d'abord créé une fonction de gestion des erreurs personnalisée custom_error_handler. Ensuite, utilisez la fonction set_error_handler pour définir la fonction en tant que gestionnaire d'erreurs global. Ensuite, le processus de gestion des erreurs est démontré en faisant écho à une variable non définie et en déclenchant une erreur personnalisée.

4. Conclusion

En utilisant la fonction set_error_handler, nous pouvons enregistrer les informations d'erreur PHP dans le fichier journal pour faciliter notre suivi ultérieur des erreurs et la résolution des problèmes. Cette méthode est très utile pour les équipes de développement et peut améliorer l'efficacité du développement et la qualité du code.

N'oubliez pas que la gestion des erreurs est un élément très important. Un bon mécanisme de gestion des erreurs peut améliorer la stabilité et la fiabilité de l'application. J'espère que cet article pourra aider tout le monde à mieux comprendre et utiliser les compétences de gestion des erreurs PHP 7.

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!

Étiquettes associées:
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
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!