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