set_error_handler Especifica una función de usuario como gestor de errores &reftitle.description; callablenullset_error_handler callablenullcallback interror_levelsE_ALL set_error_handler selecciona la función de usuario callback para gestionar errores en un script. Esta función puede ser utilizada para definir gestores de errores personalizados durante la ejecución, por ejemplo en aplicaciones que necesitan limpiar archivos/datos cuando ocurre un error crítico o cuando un error es generado en respuesta a ciertas condiciones (utilizando la función trigger_error). Debe recordarse que la función estándar de tratamiento de errores de PHP es completamente ignorada para los errores de tipos especificados por error_levels a menos que la función de retorno devuelva &false;. Los parámetros de la función error_reporting no tendrán efecto y el gestor de errores será llamado en cualquier caso. Sin embargo, siempre es posible leer el valor actual de la configuración de error_reporting y hacer que la función de gestión de errores reaccione en consecuencia. También debe notarse que es responsabilidad del gestor de errores detener la ejecución del script si es necesario llamando a la función exit. Si la función del gestor de errores devuelve, la ejecución del script continuará con la instrucción siguiente a la que causó el error. Los siguientes tipos de errores no pueden ser gestionados con esta función: E_ERROR, E_PARSE, E_CORE_ERROR, E_CORE_WARNING, E_COMPILE_ERROR, E_COMPILE_WARNING independientemente de dónde sean generados, así como la mayoría de los E_STRICT del archivo en el cual set_error_handler es llamado. Si un error ocurre antes de que el script sea ejecutado (por ejemplo una descarga de archivo), el gestor de errores personalizado no podrá ser llamado, ya que aún no está registrado. &reftitle.parameters; callback Si &null; es proporcionado, el gestor es reestablecido a su estado por defecto. De lo contrario, el gestor es una función de retorno con la siguiente firma: boolhandler interrno stringerrstr stringerrfile interrline arrayerrcontext errno El primer parámetro errno, será pasado el nivel de error, en forma de entero. errstr El segundo parámetro errstr, será pasado el mensaje de error, en forma de string. errfile Si el cierre acepta un tercer parámetro, errfile, será pasado el nombre del archivo en el cual el error fue identificado, en forma de string. errline Si el cierre acepta un cuarto parámetro, errline, será pasado el número de línea en la cual el error fue identificado, en forma de entero. errcontext Si el cierre acepta un quinto parámetro, errcontext, será pasado como un array que apunta a la tabla de símbolos activos en el momento en que el error ocurrió. En otras palabras, errcontext contiene un array con todas las variables que existían cuando el error fue generado. Los gestores de errores de usuario no deben modificar el contexto de error. Este parámetro es OBSOLETO a partir de PHP 7.2.0, y ELIMINADO a partir de PHP 8.0.0. Si la función definida este parámetro sin valor por defecto, un error de "too few arguments" será generado al llamarla. Si la función devuelve &false;, entonces el gestor de errores normal continúa. error_levels Sirve como máscara para llamar a la función callback de la misma forma que la opción de configuración error_reporting controla los errores que son mostrados. Sin la máscara, callback será llamado para todos los errores, independientemente del valor de error_reporting. &reftitle.returnvalues; Devuelve el último gestor de errores (si existe) en forma de callable. Si el gestor de errores interno es utilizado, &null; es devuelto. &reftitle.changelog; &Version; &Description; 8.0.0 errcontext ha sido eliminado, y ya no será pasado a los cierres de usuario. 7.2.0 errcontext se ha vuelto obsoleto. El uso de este parámetro emite una notificación E_DEPRECATED. &reftitle.examples; Gestor de errores con <function>set_error_handler</function> y <function>trigger_error</function> El ejemplo siguiente ilustra la intercepción de errores internos con generación de error y su explotación en una función de usuario: MI ERROR [$errno] $errstr
\n"; echo " Error fatal en la línea $errline en el archivo $errfile"; echo ", PHP " . PHP_VERSION . " (" . PHP_OS . ")
\n"; echo "Detención...
\n"; exit(1); case E_USER_WARNING: echo "MI ALERTA [$errno] $errstr
\n"; break; case E_USER_NOTICE: echo "MI AVISO [$errno] $errstr
\n"; break; default: echo "Tipo de error desconocido: [$errno] $errstr
\n"; break; } /* No ejecutar el gestor interno de PHP */ return true; } // Función para probar la gestión de error function scale_by_log($vect, $scale) { if (!is_numeric($scale) || $scale <= 0) { trigger_error("log(x) para x <= 0 es indefinido, usted usó: scale = $scale", E_USER_ERROR); } if (!is_array($vect)) { trigger_error("Tipo de entrada incorrecto, se esperaba un array de valores", E_USER_WARNING); return null; } $temp = array(); foreach($vect as $pos => $value) { if (!is_numeric($value)) { trigger_error("El valor en la posición $pos no es un número, se utiliza 0 (cero)", E_USER_NOTICE); $value = 0; } $temp[$pos] = log($scale) * $value; } return $temp; } // Configuración del gestor de errores $old_error_handler = set_error_handler("myErrorHandler"); // Generación de algunos errores. Comencemos creando un array echo "vector a\n"; $a = array(2, 3, "foo", 5.5, 43.3, 21.11); print_r($a); // Generemos ahora un segundo array echo "----\nvector b - un aviso (b = log(PI) * a)\n"; /* Valor en la posición $pos no es un número, se utiliza 0 (cero) */ $b = scale_by_log($a, M_PI); print_r($b); // Esto es un problema, hemos utilizado una cadena en lugar de un array echo "----\nvector c - una advertencia\n"; /* Tipo de entrada incorrecto, se esperaba un array de valores */ $c = scale_by_log("no un array", 2.3); var_dump($c); // NULL // Esto es un error crítico: el logaritmo de cero o de un número negativo es indefinido echo "----\nvector d - error fatal\n"; /* log(x) para x <= 0 es indefinido, usted usó: scale = $scale" */ $d = scale_by_log($a, -2.5); var_dump($d); // Nunca alcanzado ?> ]]>
&example.outputs.similar; 2 [1] => 3 [2] => foo [3] => 5.5 [4] => 43.3 [5] => 21.11 ) ---- vector b - un aviso (b = log(PI) * a) MI AVISO [1024] El valor en la posición 2 no es un número, se utiliza 0 (cero)
Array ( [0] => 2.2894597716988 [1] => 3.4341896575482 [2] => 0 [3] => 6.2960143721717 [4] => 49.566804057279 [5] => 24.165247890281 ) ---- vector c - una advertencia MI ALERTA [512] Entrada incorrecta, se esperaba un array de valores
NULL ---- vector d - error fatal MI ERROR [256] log(x) para x <= 0 es indefinido, usted usó: scale = -2.5
Error fatal en la línea 36 en el archivo trigger_error.php, PHP 4.0.2 (Linux)
Abandono...
]]>
&reftitle.seealso; ErrorException error_reporting restore_error_handler get_error_handler trigger_error Constantes de nivel de error