Gestion des erreurs PHP
En PHP, la gestion des erreurs par défaut est très simple. Un message d'erreur est envoyé au navigateur avec le nom du fichier, le numéro de ligne et un message décrivant l'erreur.
Gestion des erreurs PHP
La gestion des erreurs est un élément important lors de la création de scripts et d'applications Web. Si votre code manque de codage de détection d’erreurs, le programme n’aura pas l’air professionnel et ouvrira la porte à des risques de sécurité.
Ce tutoriel couvre certaines des méthodes de détection d'erreurs les plus importantes en PHP.
Nous vous expliquerons différentes méthodes de gestion des erreurs : 🎜>· Rapport d'erreurs
Gestion des erreurs de base : utilisation de la fonction die()Le premier exemple montre un script simple qui ouvre un fichier texte :<?php $file=fopen("welcome.txt","r"); ?>
Avertissement : fopen(welcome.txt ) [function.fopen] : échec d'ouverture du flux :
Aucun fichier ou répertoire de ce type dans /www/test/test/test.php à la ligne 2
Pour éviter que les utilisateurs ne reçoivent des messages d'erreur comme ce qui précède, nous vérifions si le fichier existe avant d'y accéder :
<?php if(!file_exists("welcome.txt")) { die("文件不存在"); } else { $file=fopen("welcome.txt","r"); } ?>
Maintenant, si le fichier n'existe pas, vous obtiendrez un message d'erreur comme celui-ci :
Le fichier n'existe pas
Le code ci-dessus est plus efficace que le code précédent, car il utilise un mécanisme simple de gestion des erreurs pour terminer le script après une erreur.
Cependant, simplement mettre fin au script n'est pas toujours approprié. Examinons les fonctions PHP alternatives pour gérer les erreurs.
Création d'un gestionnaire d'erreurs personnalisé Créer un gestionnaire d'erreurs personnalisé est très simple. Nous avons simplement créé une fonction dédiée qui peut être appelée lorsqu'une erreur survient en PHP.
La fonction doit être capable de gérer au moins deux paramètres (niveau d'erreur et message d'erreur), mais peut accepter jusqu'à cinq paramètres (facultatif : fichier, numéro de ligne et contexte d'erreur) :
Syntaxe
error_function(error_level,error_message,
error_file,error_line,error_context)
Ces niveaux de rapport d'erreurs sont différents types d'erreurs gérés par des gestionnaires d'erreurs définis par l'utilisateur :
Maintenant, créons une fonction qui gère les erreurs :
<?php function customError($errno, $errstr) { echo "<b>Error:</b> [$errno] $errstr<br>"; echo "脚本结束"; die(); } ?>
Le code ci-dessus est une simple fonction de gestion des erreurs. Lorsqu'il est déclenché, il obtient le niveau d'erreur et le message d'erreur. Il imprime ensuite le niveau d'erreur et le message, puis termine le script.
Maintenant que nous avons créé une fonction de gestion des erreurs, nous devons déterminer quand la déclencher.
Définir le gestionnaire d'erreurs
Le gestionnaire d'erreurs par défaut de PHP est le gestionnaire d'erreurs intégré. Nous allons transformer la fonction ci-dessus en gestionnaire d'erreurs par défaut lorsque le script est en cours d'exécution.
Le gestionnaire d'erreurs peut être modifié pour s'appliquer uniquement à certaines erreurs, afin que le script puisse gérer différentes erreurs de différentes manières. Cependant, dans ce cas, nous allons utiliser notre gestionnaire d'erreurs personnalisé pour toutes les erreurs :
set_error_handler("customError");
Puisque nous voulons que notre fonction personnalisée gère toutes les erreurs, set_error_handler() ne nécessite qu'un seul paramètre, et un deuxième paramètre peut être ajouté pour spécifier le niveau d'erreur.
Exemple
Testez ce gestionnaire d'erreurs en essayant de générer une variable qui n'existe pas :
<?php // 错误处理函数 function customError($errno, $errstr) { echo "<b>Error:</b> [$errno] $errstr"; } // 设置错误处理函数 set_error_handler("customError"); // 触发错误 echo($test); ?>
La sortie du code ci-dessus ressemble à ceci :
Erreur : [8] Variable non définie : test
Erreur de déclenchement
Lorsque l'utilisateur saisit des données dans le script, il est utile de déclencher une erreur lorsque la saisie de l'utilisateur n'est pas valide. En PHP, cette tâche est accomplie par la fonction trigger_error().
Exemple
Dans cet exemple, si la variable "test" est supérieure à "1", une erreur se produira :
<?php $test=2; if ($test>1) { trigger_error("变量值必须小于等于 1"); } ?>
La sortie du code ci-dessus ressemblera comme ceci :
Remarque : la valeur de la variable doit être inférieure ou égale à 1
dans /www/test/text.php à la ligne 5
Vous pouvez déclencher une erreur n'importe où dans le script en ajoutant le premier Avec deux paramètres, vous pouvez spécifier le niveau d'erreur à déclencher.
Types d'erreurs possibles :
E_USER_ERROR - Erreur d'exécution fatale générée par l'utilisateur. L'erreur ne peut pas être récupérée. L'exécution du script a été interrompue.
· E_USER_WARNING - Avertissement d'exécution non fatal généré par l'utilisateur. L'exécution du script n'est pas interrompue.
· E_USER_NOTICE - Par défaut. Notifications d'exécution générées par l'utilisateur. Se produit lorsque le script détecte une erreur possible, mais peut également se produire lorsque le script s'exécute normalement.
Exemple
Dans cet exemple, si la variable "test" est supérieure à "1", l'erreur E_USER_WARNING se produit. Si E_USER_WARNING se produit, nous utiliserons notre gestionnaire d'erreurs personnalisé et terminerons le script :
<?php // 错误处理函数 function customError($errno, $errstr) { echo "<b>Error:</b> [$errno] $errstr<br>"; echo "脚本结束"; die(); } // 设置错误处理函数 set_error_handler("customError",E_USER_WARNING); // 触发错误 $test=2; if ($test>1) { trigger_error("变量值必须小于等于 1",E_USER_WARNING); } ?>
La sortie du code ci-dessus ressemblera à ceci :
Erreur : [512] La valeur de la variable doit être inférieure supérieur ou égal à 1
Fin du script
Maintenant que nous avons appris comment créer nos propres erreurs et comment les déclencher, étudions la journalisation des erreurs.
Journalisation des erreurs
Par défaut, PHP envoie la journalisation des erreurs au système de journalisation ou au fichier du serveur selon la configuration error_log dans php.ini. En utilisant la fonction error_log(), vous pouvez envoyer des enregistrements d'erreurs vers un fichier spécifié ou une destination distante.
Vous envoyer un message d'erreur par e-mail est un excellent moyen d'être averti d'une erreur spécifiée.
Envoyer un message d'erreur par e-mail
Dans l'exemple ci-dessous, si une erreur spécifique se produit, nous enverrons un e-mail avec un message d'erreur et terminerons le script :
<?php // 错误处理函数 function customError($errno, $errstr) { echo "<b>Error:</b> [$errno] $errstr<br>"; echo "已通知网站管理员"; error_log("Error: [$errno] $errstr",1, "123123@qq.com","From: 123123@qq.com"); } // 设置错误处理函数 set_error_handler("customError",E_USER_WARNING); // 触发错误 $test=2; if ($test>1) { trigger_error("变量值必须小于等于 1",E_USER_WARNING); } ?>
Le la sortie du code ci-dessus est la suivante :
Erreur : [512] La valeur de la variable doit être inférieure ou égale à 1
L'administrateur du site Web a été averti
Reçu de le code ci-dessus L'email ressemble à ceci :
Erreur : [512] La valeur de la variable doit être inférieure ou égale à 1
Cette méthode ne convient pas à toutes les erreurs. Les erreurs générales doivent être enregistrées sur le serveur à l'aide du système de journalisation PHP par défaut.