Inicio Informática Cómo crear un registro de errores de tu web con PHP
variables predefinidas PHP

Cómo crear un registro de errores de tu web con PHP

por entreunosyceros
Publicado el Última actualización el

registro de errores PHPDespués de un tiempo demasiado ocupado para publicar, he recordado el otro día que tenía esta página funcionando en la que puedo dejar apuntado un pequeño ejercicio con el que poder crear un registro de errores con el que poder controlar los errores que genere nuestra web. En mi caso diré que lo he utilizado mientras montaba un Prestashop 1.6.1.1 y bueno, aclarar también que el listado de ordenes PHP no lo he desarrollado yo, a mi me lo ha pasado un tal Manuel, pero que si lo buscas por la red aparecerá en más sitios que este.

El script para crear el registro de errores que tienes que pegar en el archivo index.php de tu web son las siguientes:

/******************* REGISTRO ERRORES **********************/ error_reporting(E_ALL & E_NOTICE & E_STRICT & E_DEPRECATED); $old_error_handler = set_error_handler("userErrorHandler"); function userErrorHandler ($errno, $errmsg, $filename, $linenum,  $vars){ $time=date("d M Y H:i:s"); // Se toma el error según el número encontrado $errortype = array (1    => "Error", 2    => "Warning", 4    => "Parsing Error", 8    => "Notice", 16   => "Core Error", 32   => "Core Warning", 64   => "Compile Error", 128  => "Compile Warning", 256  => "User Error", 512  => "User Warning", 1024 => "User Notice"); $errlevel=$errortype[$errno]; //Escribir en un archivo excel (formato CSV) $errfile=fopen("errors.csv","a"); //fputs($errfile,'"'.$time.'";"'.$filename.'";"'.$linenum.'";"'.$errno.' ('.$errlevel.') '.$errmsg.'";"'.print_r($vars,true).'";'. "rn"); fputs($errfile,'"'.$time.'";"'.$filename.'";"'.$linenum.'";"'.$errno.' ('.$errlevel.') '.$errmsg.'";'."rn"); fclose($errfile); if($errno!=2 && $errno!=8) { //Se termina el script si se produce un error fatal die("Error fatal. El script ha sido abortado"); } } 

Con esto conseguiremos que cada vez que se ejecute la web (bien sea en el home, categoría o productos) y Prestashop (en este caso) encuentre algún error, warning, parsing error, notice, o cualquier otro de los que indicamos líneas más arriba. Estos mensajes serán guardados en un archivo llamado errors.csv (que podremos abrir con un excel cualquiera). Dentro del archivo encontraremos  el número de error, el nombre y la ubicación del archivo dónde se produce, la línea y el tipo de error. Sabiendo todo esto y teniendo paciencia (en algunos casos) podremos reparar la web justo en los puntos en los que lo necesite.

Diré que errores como los Notice, no son errores realmente. En muchisimos casos me he encontrado con que Notice  no afecta en absoluto al funcionamiento de la web, supongo que dependerá que tipo de servidor utilicemos para la web.

Con esto doy por terminado este post a modo de recordatorio. Próximamente más unos y ceros.


También te puede interesar ...

1 Comentario

SapoClay 12 octubre, 2015 - 2:29 AM

Hubo algunos problemas al copiar y pegar el código (los > y los < han sido sustituidos por sus correspondientes caracteres & amp; y =& gt;

Responder

Deja tu comentario

* Al utilizar este formulario, acepta que este sitio web almacene y maneje sus datos.

Este sitio usa Akismet para reducir el spam. Aprende cómo se procesan los datos de tus comentarios.

logo expressVPN - Obtén 30 días gratis

Si te preocupa la seguridad de tus datos, o si quieres saltarte los geobloqueos para ver tus streamings favoritos, consigue una VPN segura y de calidad GRATIS durante 30 días (cancela cuando tú quieras, sin coste alguno). Disponible para todas las plataformas y navegadores.