array ( 0 => 'index.php', 1 => 'PHP Manual', ), 'head' => array ( 0 => 'UTF-8', 1 => 'fr', ), 'this' => array ( 0 => 'class.errorexception.php', 1 => 'ErrorException', ), 'up' => array ( 0 => 'reserved.exceptions.php', 1 => 'Exceptions prédéfinies', ), 'prev' => array ( 0 => 'exception.clone.php', 1 => 'Exception::__clone', ), 'next' => array ( 0 => 'errorexception.construct.php', 1 => 'ErrorException::__construct', ), 'alternatives' => array ( ), 'source' => array ( 'lang' => 'fr', 'path' => 'language/predefined/errorexception.xml', ), 'extra_header_links' => array ( 'rel' => 'alternate', 'href' => '/manual/en/feeds/class.errorexception.atom', 'type' => 'application/atom+xml', ), ); $setup["toc"] = $TOC; $setup["toc_deprecated"] = $TOC_DEPRECATED; $setup["parents"] = $PARENTS; manual_setup($setup); ?>
(PHP 5 >= 5.1.0, PHP 7, PHP 8)
Une exception pour les erreurs.
La sévérité de l'exception
Exemple #1 Utilisation de set_error_handler() pour changer tous les messages d'erreurs en ErrorException
<?php
function exception_error_handler(int $errno, string $errstr, string $errfile = null, int $errline) {
if (!(error_reporting() & $errno)) {
// Ce code d'erreur n'est pas inclus dans error_reporting
return;
}
throw new \ErrorException($errstr, 0, $errno, $errfile, $errline);
}
set_error_handler(exception_error_handler(...));
Antérieur à PHP 8.1.0 et l'introduction de la première syntaxe de classe callable, l'appel suivant doit être utilisé à la place :"
"set_error_handler(NAMESPACE . '\exception_error_handler');
/* Lance l'exception */
strpos();
?>
Résultat de l'exemple ci-dessus est similaire à :
Fatal error: Uncaught exception 'ErrorException' with message 'strpos() expects at least 2 parameters, 0 given' in /home/bjori/tmp/ex.php:12 Stack trace: #0 [internal function]: exception_error_handler(2, 'strpos() expect...', '/home/bjori/php...', 12, Array) #1 /home/bjori/php/cleandocs/test.php(12): strpos() #2 {main} thrown in /home/bjori/tmp/ex.php on line 12