Explication détaillée sur les erreurs de capture PHP

藏色散人
Libérer: 2023-03-02 13:02:01
original
3142 Les gens l'ont consulté

Comment détecter les erreurs en PHP : 1. Utilisez la méthode "try{}catch()" pour détecter les erreurs ; 2. Utilisez la fonction "set_error_handler" pour détecter "E_NOTICE", etc. ; "set_exception_handler" pour définir le gestionnaire d'exceptions par défaut.

Explication détaillée sur les erreurs de capture PHP

Capture d'erreurs et d'exceptions PHP

Dans le développement réel, la capture d'erreurs et d'exceptions repose uniquement sur try{}catch () est loin d'être suffisant.

Citez donc les fonctions suivantes.

a) set_error_handler

est généralement utilisé pour capturer E_NOTICE, E_USER_ERROR, E_USER_WARNING, E_USER_NOTICE

Impossible de capturer :

E_ERROR, E_PARSE, E_CORE_ERROR, E_CORE_ ATTENTION , E_COMPILE_ERROR et E_COMPILE_WARNING.

est généralement utilisé en conjonction avec trigger_error("...", E_USER_ERROR).

<?php
// we will do our own error handling
error_reporting(0);
function userErrorHandler($errno, $errmsg, $filename, $linenum, $vars)
{
    // timestamp for the error entry    
$dt = date("Y-m-d H:i:s (T)");    
// define an assoc array of error string    
// in reality the only entries we should    
// consider are E_WARNING, E_NOTICE, E_USER_ERROR,    
// E_USER_WARNING and E_USER_NOTICE    
$errortype = array (                
E_ERROR              => &#39;Error&#39;,                
E_WARNING            => &#39;Warning&#39;,                
E_PARSE              => &#39;Parsing Error&#39;,                
E_NOTICE             => &#39;Notice&#39;,                
E_CORE_ERROR         => &#39;Core Error&#39;,                
E_CORE_WARNING       => &#39;Core Warning&#39;,                
E_COMPILE_ERROR      => &#39;Compile Error&#39;,                
E_COMPILE_WARNING    => &#39;Compile Warning&#39;,                
E_USER_ERROR         => &#39;User Error&#39;,                
E_USER_WARNING       => &#39;User Warning&#39;,                
E_USER_NOTICE        => &#39;User Notice&#39;,                
E_STRICT             => &#39;Runtime Notice&#39;,                
E_RECOVERABLE_ERROR  => &#39;Catchable Fatal Error&#39;                
);    
// set of errors for which a var trace will be saved    
$user_errors = array(E_USER_ERROR, E_USER_WARNING, E_USER_NOTICE);        
$err = "<errorentry>\n";    
$err .= "\t<datetime>" . $dt . "</datetime>\n";    
$err .= "\t<errornum>" . $errno . "</errornum>\n";    
$err .= "\t<errortype>" . $errortype[$errno] . "</errortype>\n";    
$err .= "\t<errormsg>" . $errmsg . "</errormsg>\n";    
$err .= "\t<scriptname>" . $filename . "</scriptname>\n";    
$err .= "\t<scriptlinenum>" . $linenum . "</scriptlinenum>\n";    
if (in_array($errno, $user_errors)) {        
$err .= "\t<vartrace>" . wddx_serialize_value($vars, "Variables") . "</vartrace>\n";    
}    
$err .= "</errorentry>\n\n";
echo $err;
}
function distance($vect1, $vect2) {    
if (!is_array($vect1) || !is_array($vect2)) {        
trigger_error("Incorrect parameters, arrays expected", E_USER_ERROR);        
return NULL;    
}    
if (count($vect1) != count($vect2)) {        
trigger_error("Vectors need to be of the same size", E_USER_ERROR);        
return NULL;    
} 
for ($i=0; $i<count($vect1); $i++) {        
$c1 = $vect1[$i]; $c2 = $vect2[$i];        
$d = 0.0;        
if (!is_numeric($c1)) {            
trigger_error("Coordinate $i in vector 1 is not a number, using zero",E_USER_WARNING);            
$c1 = 0.0;        
}        
if (!is_numeric($c2)) {            
trigger_error("Coordinate $i in vector 2 is not a number, using zero",E_USER_WARNING);            
$c2 = 0.0;        
}
$d += $c2*$c2 - $c1*$c1;    
}    
return sqrt($d);
}
 
$old_error_handle = set_error_handler("userErrorHandler");
$t = I_AM_NOT_DEFINED;//generates a warning
 
// define some "vectors"
$a = array(2, 3, "foo");
$b = array(5.5, 4.3, -1.6);
$c = array(1, -3);
 
//generate a user error
$t1 = distance($c,$b);
 
// generate another user error
$t2 = distance($b, "i am not an array") . "\n";
 
// generate a warning
$t3 = distance($a, $b) . "\n";
?>
Copier après la connexion

b) set_exception_handler

Définissez le gestionnaire d'exceptions par défaut pour les exceptions qui ne sont pas interceptées avec des blocs try/catch. Les exceptions sont abandonnées après l'appel de exception_handler.

est utilisé avec throw new Exception (« Une exception non capturée s'est produite »).

<?php
// we will do our own error handling
error_reporting(0);
function exceptHandle($errno, $errmsg, $filename, $linenum, $vars)
{
    // timestamp for the error entry    
$dt = date("Y-m-d H:i:s (T)");    
// define an assoc array of error string    
// in reality the only entries we should    
// consider are E_WARNING, E_NOTICE, E_USER_ERROR,    
// E_USER_WARNING and E_USER_NOTICE    
$errortype = array (                
E_ERROR              => &#39;Error&#39;,                
E_WARNING            => &#39;Warning&#39;,                
E_PARSE              => &#39;Parsing Error&#39;,                
E_NOTICE             => &#39;Notice&#39;,                
E_CORE_ERROR         => &#39;Core Error&#39;,                
E_CORE_WARNING       => &#39;Core Warning&#39;,                
E_COMPILE_ERROR      => &#39;Compile Error&#39;,                
E_COMPILE_WARNING    => &#39;Compile Warning&#39;,                
E_USER_ERROR         => &#39;User Error&#39;,                
E_USER_WARNING       => &#39;User Warning&#39;,                
E_USER_NOTICE        => &#39;User Notice&#39;,                
E_STRICT             => &#39;Runtime Notice&#39;,                
E_RECOVERABLE_ERROR  => &#39;Catchable Fatal Error&#39;                
);    
// set of errors for which a var trace will be saved    
$err = "<errorentry>\n";    
$err .= "\t<datetime>" . $dt . "</datetime>\n";    
$err .= "\t<errornum>" . $errno . "</errornum>\n";    
$err .= "\t<errortype>" . $errortype[$errno] . "</errortype>\n";    
$err .= "\t<errormsg>" . $errmsg . "</errormsg>\n";    
$err .= "\t<scriptname>" . $filename . "</scriptname>\n";    
$err .= "\t<scriptlinenum>" . $linenum . "</scriptlinenum>\n";    
if (1) {        
$err .= "\t<vartrace>" . wddx_serialize_value($vars, "Variables") . "</vartrace>\n";    
}    
$err .= "</errorentry>\n\n";
echo $err;
}
$old_except_handle = set_exception_handler("exceptHandle");
//$t = I_AM_NOT_DEFINED;//generates a warning
$a;
throw new Exception(&#39;Uncaught Exception occurred&#39;);    
?>
Copier après la connexion

c) register_shutdown_function

Le mécanisme d'exécution est le suivant : php transfère la fonction à appeler en mémoire. Cette fonction est appelée à nouveau lorsque toutes les instructions PHP de la page ont été exécutées.

est généralement utilisé en conjonction avec trigger_error("...", E_USER_ERROR).

<?php
error_reporting(0);
date_default_timezone_set(&#39;Asia/Shanghai&#39;);
register_shutdown_function(&#39;my_exception_handler&#39;);
 
$t = I_AM_NOT_DEFINED;//generates a warning
trigger_error("Vectors need to be of the same size", E_USER_ERROR);     
 
function my_exception_handler()
{
    if($e = error_get_last()) {
    //$e[&#39;type&#39;]对应php_error常量
    $message = &#39;&#39;;
    $message .= "出错信息:\t".$e[&#39;message&#39;]."\n\n";
    $message .= "出错文件:\t".$e[&#39;file&#39;]."\n\n";
    $message .= "出错行数:\t".$e[&#39;line&#39;]."\n\n";
    $message .= "\t\t请工程师检查出现程序".$e[&#39;file&#39;]."出现错误的原因\n";
    $message .= "\t\t希望能您早点解决故障出现的原因<br/>";
echo $message;
    //sendemail to
    }
}
?>
Copier après la connexion

c) fonction restaurer_error_handler()

Définition et utilisation La fonction restaurer_error_handler() restaure le gestionnaire d'erreurs précédent, qui a été modifié par la fonction set_error_handler().

Cette fonction renvoie toujours vrai.

est la fonction inverse de set_error_handler().

Pour plus de connaissances connexes, veuillez visiter le Site Web PHP chinois !

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
php
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!