Gestion des exceptions dans le didacticiel de base du développement PHP

1. Qu'est-ce qu'une anomalie ?

Les exceptions sont utilisées pour modifier le flux normal d'un script lorsqu'une erreur spécifiée se produit.

PHP 5 fournit une nouvelle méthode de gestion des erreurs orientée objet.

La gestion des exceptions est utilisée pour modifier le flux normal d'un script lorsqu'une situation d'erreur (exception) spécifiée se produit. Cette situation est appelée une exception.

Lorsqu'une exception est déclenchée, ce qui se passe généralement est :

  • L'état actuel du code est enregistré

  • L'exécution du code est basculé vers des fonctions de gestionnaire d'exceptions prédéfinies (personnalisées)

  • Selon la situation, le gestionnaire peut redémarrer l'exécution du code à partir de l'état du code enregistré, terminer l'exécution du script ou démarrer une autre étape dans le code Continuer exécution du script à l'emplacement

  • Nous montrerons différentes méthodes de gestion des erreurs :

  • Utilisation de base des exceptions

  • Créer un gestionnaire d'exceptions personnalisé

  • Exceptions multiples

  • Relancer les exceptions

  • Définir haut- gestionnaire d'exceptions de niveau

Remarque : les exceptions ne doivent être utilisées que dans des situations d'erreur et ne doivent pas être utilisées pour accéder à une autre partie du code à un emplacement spécifié.




Utilisation de base des exceptions

Lorsqu'une exception est levée, le code suivant ne continuera pas à s'exécuter et PHP tentera de trouver un bloc de code "catch" correspondant.

Si l'exception n'est pas interceptée et n'est pas gérée en conséquence à l'aide de set_exception_handler(), une erreur grave (erreur fatale) se produira et une erreur "Exception non capturée" sera générée.

Essayons de lancer une exception sans l'attraper :

Le code est le suivant :

<?php
// 创建一个有异常处理的函数
function checkNum($number)
{
	if($number>1)
	{
		throw new Exception("Value must be 1 or below");
	}
	return true;
}
// 触发异常
checkNum(2);
?>

Vous obtiendrez un résultat comme celui-ci :

64.png


3. Essayez, lancez et attrapez

Pour éviter les erreurs de l'exemple ci-dessus, nous devons créer le code approprié pour gérer les exceptions.

Le code de gestion des exceptions approprié doit inclure :

  • Try - Les fonctions qui utilisent des exceptions doivent être situées dans un bloc de code "try". Si aucune exception n'est déclenchée, le code continue son exécution comme d'habitude. Mais si une exception est déclenchée, une exception sera levée.

  • Throw - spécifie comment déclencher une exception. Chaque « lancer » doit correspondre à au moins une « prise ».

  • Catch - Le bloc de code "catch" intercepte l'exception et crée un objet contenant les informations sur l'exception.

Déclenchons une exception :

Le code est le suivant

<?php
// 创建一个有异常处理的函数
function checkNum($number)
{
	if($number>1)
	{
		throw new Exception("变量值必须小于等于 1");
	}
		return true;
}
	
// 在 try 块 触发异常
try
{
	checkNum(2);
	// 如果抛出异常,以下文本不会输出
	echo '如果输出该内容,说明 $number 变量';
}
// 捕获异常
catch(Exception $e)
{
	echo 'Message: ' .$e->getMessage();
}
?>

La sortie est comme indiqué à droite

Explication des exemples :

Le code ci-dessus lève une exception et l'attrape :

  • Créez la fonction checkNum(). Il détecte si le nombre est supérieur à 1. Si c'est le cas, lancez une exception.

  • Appelez la fonction checkNum() dans le bloc de code "try".

  • Une exception dans la fonction checkNum() est levée.

  • Le bloc de code "catch" reçoit l'exception et crée un objet ($e) contenant les informations sur l'exception.

  • Sortez le message d'erreur de cette exception en appelant $e->getMessage() à partir de cet objet d'exception.

Cependant, afin de suivre le principe de "chaque lancer doit correspondre à une capture", vous pouvez configurer un gestionnaire d'exceptions de niveau supérieur pour gérer les erreurs manquées.


4. Créez une classe d'exception personnalisée

La création d'un gestionnaire d'exceptions personnalisé est très simple. Nous avons simplement créé une classe spécialisée dont les fonctions sont appelées lorsqu'une exception se produit en PHP. Cette classe doit être une extension de la classe d'exception.

Cette classe d'exception personnalisée hérite de toutes les propriétés de la classe d'exception de PHP et vous pouvez y ajouter des fonctions personnalisées.

Nous commençons à créer la classe d'exception :

Le code est le suivant

<?php
class customException extends Exception
{
	public function errorMessage()
	{
		// 错误信息
		$errorMsg = '错误行号 '.$this->getLine().' in '.$this->getFile()
		.': <b>'.$this->getMessage().'</b> 不是一个合法的 E-Mail 地址';
		return $errorMsg;
	}
}
$email = "someone@example...com";
try
{
	// 检测邮箱
	if(filter_var($email, FILTER_VALIDATE_EMAIL) === FALSE)
	{
		// 如果是个不合法的邮箱地址,抛出异常
		throw new customException($email);
	}
}
catch (customException $e)
{
//display custom message
echo $e->errorMessage();
}
?>

Le résultat de sortie est affiché dans l'image de droite

Cette nouvelle classe est l'ancienne classe d'exception. Une copie de , plus la fonction errorMessage(). Juste parce qu'il s'agit d'une copie de l'ancienne classe, elle hérite des propriétés et des méthodes de l'ancienne classe, et nous pouvons utiliser les méthodes de la classe d'exception, telles que getLine(), getFile() et getMessage().

Explication des exemples :

Le code ci-dessus lève une exception et l'attrape via une classe d'exception personnalisée :

  • Le La classe customException() a été créée comme une extension de l’ancienne classe d’exception. De cette façon, il hérite de toutes les propriétés et méthodes de l’ancienne classe d’exception.

  • Créez la fonction errorMessage(). Si l'adresse e-mail n'est pas valide, cette fonction renvoie un message d'erreur.

  • Définissez la variable $email sur une chaîne d'adresse e-mail illégale.

  • Exécutez le bloc de code "try" et lancez une exception car l'adresse e-mail n'est pas valide.

  • Le bloc de code "catch" intercepte l'exception et affiche le message d'erreur

Exceptions multiples<🎜. >

Vous pouvez utiliser plusieurs exceptions pour un script afin de détecter plusieurs situations.

Vous pouvez utiliser plusieurs blocs de code if..else, ou un bloc de code de commutation, ou imbriquer plusieurs exceptions. Ces exceptions peuvent utiliser différentes classes d'exceptions et renvoyer différents messages d'erreur :

Le code est le suivant

<?php
class customException extends Exception
{
	public function errorMessage()
	{
		// 错误信息
		$errorMsg = '错误行号 '.$this->getLine().' in '.$this->getFile()
		.': <b>'.$this->getMessage().'</b> 不是一个合法的 E-Mail 地址';
		return $errorMsg;
	}
}

$email = "someone@example.com";

try
{
	// 检测邮箱
	if(filter_var($email, FILTER_VALIDATE_EMAIL) === FALSE)
	{
		// 如果是个不合法的邮箱地址,抛出异常
		throw new customException($email);
	}
	// 检测 "example" 是否在邮箱地址中
	if(strpos($email, "example") !== FALSE)
	{
		throw new Exception("$email 是 example 邮箱");
	}
}
catch (customException $e)
{
	echo $e->errorMessage();
}
catch(Exception $e)
{
	echo $e->getMessage();
}
?>

Explication des exemples :

Le code ci-dessus test Deux conditions sont spécifiées. Si l'une des conditions n'est pas vraie, une exception est levée :

  • La classe customException() a été créée comme une extension de l'ancienne classe d'exception. De cette façon, il hérite de toutes les propriétés et méthodes de l’ancienne classe d’exception.

  • Créez la fonction errorMessage(). Si l'adresse e-mail n'est pas valide, cette fonction renvoie un message d'erreur.

  • Définissez la variable $email sur une chaîne qui est une adresse e-mail valide mais contient la chaîne "exemple".

  • Exécutez le bloc de code "try", et dans la première condition, aucune exception ne sera levée.

  • Puisque l'e-mail contient la chaîne "exemple", la deuxième condition déclenchera une exception.

  • Le bloc "catch" intercepte l'exception et affiche le message d'erreur approprié.

Si la classe customException lève une exception, mais n'attrape pas l'exception customException, mais intercepte uniquement l'exception de base, gérez l'exception à cet endroit.


6. Relancez l'exception

Parfois, lorsqu'une exception est levée, vous souhaiterez peut-être utiliser une méthode différente. que la manière standard de le traiter. L'exception peut être à nouveau levée dans un bloc "catch".

Le script doit masquer les erreurs système à l'utilisateur. Les erreurs système peuvent être importantes pour les programmeurs, mais elles ne intéressent pas les utilisateurs. Pour faciliter la tâche des utilisateurs, vous pouvez relancer l'exception avec un message plus convivial :

Le code est le suivant

<?php
class customException extends Exception
{
	public function errorMessage()
	{
		// 错误信息
		$errorMsg = $this->getMessage().' 不是一个合法的 E-Mail 地址。';
		return $errorMsg;
	}
}

$email = "someone@example.com";

try
{
	try
	{
		// 检测 "example" 是否在邮箱地址中
		if(strpos($email, "example") !== FALSE)
		{
			// 如果是个不合法的邮箱地址,抛出异常
			throw new Exception($email);
		}
	}
	catch(Exception $e)
	{
		// 重新抛出异常
		throw new customException($email);
	}
}
catch (customException $e)
{
	// 显示自定义信息
	echo $e->errorMessage();
}
?>

La sortie est affichée à droite

Explication des exemples :

Le code ci-dessus détecte si l'adresse email contient la chaîne "exemple". Si tel est le cas, lancez à nouveau l'exception :

  • La classe customException() a été créée en tant qu'extension de l'ancienne classe d'exception. De cette façon, il hérite de toutes les propriétés et méthodes de l’ancienne classe d’exception.

  • Créer la fonction errorMessage(). Si l'adresse e-mail n'est pas valide, cette fonction renvoie un message d'erreur.

  • Définissez la variable $email sur une chaîne qui est une adresse e-mail valide mais contient la chaîne "exemple".

  • Le bloc "try" contient un autre bloc "try" afin que l'exception puisse être à nouveau levée.

  • L'e-mail contenant la chaîne "exemple", une exception est déclenchée.

  • Le bloc de code "catch" intercepte l'exception et renvoie "customException".

  • intercepte "customException" et affiche un message d'erreur.

Si l'exception n'est pas interceptée dans le bloc "try" actuel, elle recherchera un bloc catch à un niveau supérieur.


7. Définir un gestionnaire d'exceptions de niveau supérieur

La fonction set_exception_handler() peut définir une fonction définie par l'utilisateur qui gère tout. exceptions non capturées.

Le code est le suivant

<?php
function myException($exception)
{
	echo "<b>Exception:</b> " , $exception->getMessage();
}

set_exception_handler('myException');

throw new Exception('Uncaught Exception occurred');
?>

La sortie est affichée à droite

Dans le code ci-dessus, il n'y a pas de bloc "catch", mais le gestionnaire d'exceptions de niveau supérieur est déclenché. Cette fonction doit être utilisée pour intercepter toutes les exceptions non interceptées.


8. Règles d'exception

  • Le code qui nécessite la gestion des exceptions doit être placé dans les blocs de code d'essai à l'intérieur pour détecter les exceptions potentielles.

  • Chaque bloc d'essai ou de lancer doit avoir au moins un bloc de capture correspondant.

  • Utilisez plusieurs blocs catch pour intercepter différents types d'exceptions.

  • Des exceptions peuvent être levées (relancées) dans un bloc catch au sein d'un bloc try.

En bref : si une exception est levée, vous devez l'attraper.


Formation continue
||
<?php // 创建一个有异常处理的函数 function checkNum($number) { if($number>1) { throw new Exception("Value must be 1 or below"); } return true; } // 触发异常 checkNum(2); ?>
soumettreRéinitialiser le code