PHP - Gestion des erreurs et des exceptions
La gestion des erreurs consiste à détecter les erreurs soulevées par votre programme, puis à prendre les mesures appropriées. Si vous gérez correctement les erreurs, cela peut entraîner de nombreuses conséquences imprévues.
C'est très simple en PHP pour gérer les erreurs.
Utilisation de la fonction die ()
Lors de l'écriture de votre programme PHP, vous devez vérifier toutes les conditions d'erreur possibles avant de continuer et prendre les mesures appropriées si nécessaire.
Essayez de suivre l'exemple sans avoir /tmp/test.xt fichier et avec ce fichier.
<?php
if(!file_exists("/tmp/test.txt")) {
die("File not found");
}else {
$file = fopen("/tmp/test.txt","r");
print "Opend file sucessfully";
}
// Test of the code here.
?>
De cette façon, vous pouvez écrire un code efficace. En utilisant la technique ci-dessus, vous pouvez arrêter votre programme en cas d'erreur et afficher un message plus significatif et convivial.
Définition de la fonction de gestion des erreurs personnalisée
Vous pouvez écrire votre propre fonction pour gérer toute erreur. PHP vous fournit un cadre pour définir la fonction de gestion des erreurs.
Cette fonction doit être capable de gérer un minimum de deux paramètres (niveau d'erreur et message d'erreur) mais peut accepter jusqu'à cinq paramètres (éventuellement: fichier, numéro de ligne et contexte d'erreur) -
Syntaxe
error_function(error_level,error_message, error_file,error_line,error_context);
Sr. Non | Paramètre et description |
---|---|
1 | error_level Obligatoire - Spécifie le niveau de rapport d'erreur pour l'erreur définie par l'utilisateur. Doit être un nombre de valeur. |
2 |
error_message Obligatoire - Spécifie le message d'erreur pour l'erreur définie par l'utilisateur |
3 |
error_file Facultatif - Spécifie le nom du fichier dans lequel l'erreur s'est produite |
4 | error_line Facultatif - Spécifie le numéro de ligne dans lequel l'erreur s'est produite |
5 | error_context Facultatif - Spécifie un tableau contenant toutes les variables et leurs valeurs utilisées lorsque l'erreur s'est produite |
Niveaux d'erreur possibles
Ces niveaux de rapport d'erreurs sont les différents types d'erreur pour lesquels le gestionnaire d'erreurs défini par l'utilisateur peut être utilisé. Ces valeurs sont utilisées en combinaison avec| opérateur
Sr. Non | Constante et description | Valeur |
---|---|---|
1 | .E_ERROR Erreurs d'exécution fatales. L'exécution du script est interrompue |
1 |
2 | E_WARNING Erreurs d'exécution non fatales. L'exécution du script n'est pas interrompue |
2 |
3 | E_PARSE Erreurs d'analyse lors de la compilation. Les erreurs d'analyse ne doivent être générées que par l'analyseur. |
4 |
4 | E_NOTICE Avis d'exécution. Le script a trouvé quelque chose qui pourrait être une erreur, mais qui pourrait également se produire lors de l'exécution normale d'un script |
8 |
5 | E_CORE_ERROR Erreurs fatales qui se produisent lors du démarrage initial de PHP. |
16 |
6 | E_CORE_WARNING Erreurs d'exécution non fatales. Cela se produit lors du démarrage initial de PHP. |
32 |
sept | E_USER_ERROR Erreur fatale générée par l'utilisateur. C'est comme un E_ERROR défini par le programmeur en utilisant la fonction PHP trigger_error () |
256 |
8 | E_USER_WARNING Avertissement généré par l'utilisateur non fatal. C'est comme un E_WARNING défini par le programmeur en utilisant la fonction PHP trigger_error () |
512 |
9 | E_USER_NOTICE Avis généré par l'utilisateur. C'est comme un E_NOTICE défini par le programmeur en utilisant la fonction PHP trigger_error () |
1024 |
dix | E_STRICT Avis d'exécution. Permettez à PHP de suggérer des modifications à votre code qui assureront la meilleure interopérabilité et la compatibilité ascendante de votre code. |
2048 |
11 | E_RECOVERABLE_ERROR Erreur fatale capturable. C'est comme un E_ERROR mais peut être intercepté par un handle défini par l'utilisateur (voir aussi set_error_handler ()) |
4096 |
12 | E_ALL Toutes les erreurs et avertissements, sauf le niveau E_STRICT (E_STRICT fera partie de E_ALL à partir de PHP 6.0) |
8191 |
Tous les niveaux d'erreur ci-dessus peuvent être définis en utilisant la fonction de bibliothèque intégrée PHP suivante, où level cab correspond à l'une des valeurs définies dans le tableau ci-dessus.
int error_reporting ( [int $level] )
Voici la façon dont vous pouvez créer une fonction de gestion des erreurs -
<?php
function handleError($errno, $errstr,$error_file,$error_line) {
echo "<b>Error:</b> [$errno] $errstr - $error_file:$error_line";
echo "<br />";
echo "Terminating PHP Script";
die();
}
?>
Une fois que vous avez défini votre gestionnaire d'erreur personnalisé, vous devez le définir à l'aide de la bibliothèque intégrée PHP set_error_handlerfonction. Examinons maintenant notre exemple en appelant une fonction qui n'existe pas.
<?php
error_reporting( E_ERROR );
function handleError($errno, $errstr,$error_file,$error_line) {
echo "<b>Error:</b> [$errno] $errstr - $error_file:$error_line";
echo "<br />";
echo "Terminating PHP Script";
die();
}
//set error handler
set_error_handler("handleError");
//trigger error
myFunction();
?>
Gestion des exceptions
PHP 5 a un modèle d'exception similaire à celui des autres langages de programmation. Les exceptions sont importantes et permettent de mieux contrôler la gestion des erreurs.
Expliquons-y un nouveau mot-clé lié aux exceptions.
Try- Une fonction utilisant une exception doit être dans un bloc "try". Si l'exception ne se déclenche pas, le code continuera normalement. Cependant, si l'exception se déclenche, une exception est "levée".
Throw- C'est ainsi que vous déclenchez une exception. Chaque «lancer» doit avoir au moins une «prise».
Catch - Un bloc "catch" récupère une exception et crée un objet contenant les informations d'exception.
Lorsqu'une exception est levée, le code suivant l'instruction ne sera pas exécuté et PHP tentera de trouver le premier bloc catch correspondant. Si une exception n'est pas interceptée, une erreur fatale PHP sera émise avec une "Exception non interceptée ...
Une exception peut être lancée et interceptée ("attrapée") dans PHP. Le code peut être entouré d'un bloc try.
Chaque essai doit avoir au moins un bloc catch correspondant. Plusieurs blocs catch peuvent être utilisés pour intercepter différentes classes d'exceptions.
Les exceptions peuvent être lancées (ou relancées) dans un bloc catch.
Exemple
Voici le morceau de code, copiez et collez ce code dans un fichier et vérifiez le résultat.
<?php
try {
$error = 'Always throw this error';
throw new Exception($error);
// Code following an exception is not executed.
echo 'Never executed';
}catch (Exception $e) {
echo 'Caught exception: ', $e->getMessage(), "\n";
}
// Continue execution
echo 'Hello World';
?>
Dans l'exemple ci-dessus, la fonction $ e-> getMessage est utilisée pour obtenir un message d'erreur. Les fonctions suivantes peuvent être utilisées à partir deException classe.
getMessage() - message d'exception
getCode() - code d'exception
getFile() - nom du fichier source
getLine() - ligne source
getTrace() - n tableau du backtrace ()
getTraceAsString() - chaîne de trace formatée
Création d'un gestionnaire d'exceptions personnalisé
Vous pouvez définir votre propre gestionnaire d'exceptions personnalisé. Utilisez la fonction suivante pour définir une fonction de gestionnaire d'exceptions définie par l'utilisateur.
string set_exception_handler ( callback $exception_handler )
Ici exception_handlerest le nom de la fonction à appeler lorsqu'une exception non interceptée se produit. Cette fonction doit être définie avant d'appeler set_exception_handler ().
Exemple
<?php
function exception_handler($exception) {
echo "Uncaught exception: " , $exception->getMessage(), "\n";
}
set_exception_handler('exception_handler');
throw new Exception('Uncaught Exception');
echo "Not Executed\n";
?>
Vérifiez l'ensemble complet des fonctions de gestion des erreurs dans Fonctions de gestion des erreurs PHP