downloads | documentation | faq | getting help | mailing lists | licenses | wiki | reporting bugs | php.net sites | links | conferences | my php.net

search for in the

Error Handling Functions> <Constantes predefinidas
Last updated: Thu, 17 Sep 2009

view this page in

Ejemplos

A continuación podemos apreciar un ejemplo del uso de las capacidades de gestión de errores que vienen con PHP. Definimos una función de manipulación de errores que registra la información en un archivo (usando un formato XML), y envía un correo electrónico al desarrollador en caso de que un error crítico en la lógica del software ocurra.

Example #1 Uso de gestión de errores en un script

<?php
// haremos nuestra propia manipulación de errores
error_reporting(0);

// función de gestión de errores definida por el usuario
function gestorDeErroresDeUsuario($num_err$mens_err$nombre_archivo,
                                  
$num_linea$vars)
{

    
// marca de fecha/hora para el registro de error
    
$dt date("Y-m-d H:i:s (T)");

    
// definir una matriz asociativa de cadenas de error
    // en realidad las únicas entradas que deberíamos
    // considerar son E_WARNING, E_NOTICE, E_USER_ERROR,
    // E_USER_WARNING y E_USER_NOTICE

    
$tipo_error = array (
                
E_ERROR              => 'Error',
                
E_WARNING            => 'Advertencia',
                
E_PARSE              => 'Error de Intérprete',
                
E_NOTICE             => 'Anotación',
                
E_CORE_ERROR         => 'Error de Núcleo',
                
E_CORE_WARNING       => 'Advertencia de Núcleo',
                
E_COMPILE_ERROR      => 'Error de Compilación',
                
E_COMPILE_WARNING    => 'Advertencia de Compilación',
                
E_USER_ERROR         => 'Error de Usuario',
                
E_USER_WARNING       => 'Advertencia de Usuario',
                
E_USER_NOTICE        => 'Anotación de Usuario',
                
E_STRICT             => 'Anotación de tiempo de ejecución',
                
E_RECOVERABLE_ERROR  => 'Error Fatal Atrapable'
                
);
    
// conjunto de errores de los cuales se almacenará un rastreo
    
$errores_de_usuario = array(E_USER_ERRORE_USER_WARNINGE_USER_NOTICE);

    
$err "<errorentry>\n";
    
$err .= "\t<datetime>" $dt "</datetime>\n";
    
$err .= "\t<errornum>" $num_err "</errornum>\n";
    
$err .= "\t<errortype>" $tipo_error[$num_err] . "</errortype>\n";
    
$err .= "\t<errormsg>" $mens_err "</errormsg>\n";
    
$err .= "\t<scriptname>" $nombre_archivo "</scriptname>\n";
    
$err .= "\t<scriptlinenum>" $num_linea "</scriptlinenum>\n";

    if (
in_array($num_err$errores_de_usuario)) {
        
$err .= "\t<vartrace>" wddx_serialize_value($vars"Variables") . "</vartrace>\n";
    }
    
$err .= "</errorentry>\n\n";

    
// para efectos de depuración
    // echo $err;

    // guardar en el registro de errores, y enviar un correo
    // electrónico si hay un error crítico de usuario
    
error_log($err3"/usr/local/php4/error.log");
    if (
$num_err == E_USER_ERROR) {
        
mail("phpdev@example.com""Error Crítico de Usuario"$err);
    }
}


function 
distancia($vect1$vect2)
{
    if (!
is_array($vect1) || !is_array($vect2)) {
        
trigger_error("Parámetros incorrectos, se esperan matrices"E_USER_ERROR);
        return 
NULL;
    }

    if (
count($vect1) != count($vect2)) {
        
trigger_error("Los vectores deben ser del mismo tamaño"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("La coordenada $i en el vector 1 no es un ".
                          
"número, se usará cero",
                            
E_USER_WARNING);
            
$c1 0.0;
        }
        if (!
is_numeric($c2)) {
            
trigger_error("La coordenada $i en el vector 2 no es un".
                          
"número, se usará cero",
                            
E_USER_WARNING);
            
$c2 0.0;
        }
        
$d += $c2*$c2 $c1*$c1;
    }
    return 
sqrt($d);
}

$gestor_de_errores_anterior set_error_handler("gestorDeErroresDeUsuario");

// constante indefinida, se genera una advertencia
$t NO_ESTOY_DEFINIDA;

// definir algunos "vectores"
$a = array(23"foo");
$b = array(5.54.3, -1.6);
$c = array(1, -3);

// generar un error de usuario
$t1 distance($c$b) . "\n";

// generar otro error de usuario
$t2 distance($b"no soy una matriz") . "\n";

// generar una advertencia
$t3 distance($a$b) . "\n";

?>



add a note add a note User Contributed Notes
Ejemplos
There are no user contributed notes for this page.

Error Handling Functions> <Constantes predefinidas
Last updated: Thu, 17 Sep 2009
 
 
show source | credits | sitemap | contact | advertising | mirror sites