Accueil > > > GESTION DES ERREURS (ENREGISTREMENT EN BASE DE DONNÉE)
GESTION DES ERREURS (ENREGISTREMENT EN BASE DE DONNÉE)
Information sur la source
Description
Ce code enregistre les erreurs PHP rencontrées dans une base de donnée, il stoppe le script si ces erreurs sont trop importante, et enregistre la date où l'erreur s'est produite. Ce code est une variante du code de Samiby. Ayant trouvé le script très interressant je m'en suis inspiré pour en faire une petite variante.
Source
- <?php
- function erreurphp( $errno , $errmsg , $errfichier , $errligne , $errcontext ){
- $date = date( 'd/m/Y H:i:s' );
- switch( $errno ){
- //gestion des erreurs importantes
- case 1:
- case 16:
- case 64:
- case 256:
- //Enregistrement de l'erreur
- ecriture_base( $date , $errno , $errmsg , $errfichier , $errligne , 0 );
- //arret du script
- die( 'Erreur : Rééssayez plus tard.' );
- //Gestion des erreurs moyennement importantes
- case 2:
- case 4:
- case 32:
- case 128:
- case 512:
- //Enregistrement de l'erreur
- ecriture_base( $date , $errno , $errmsg , $errfichier , $errligne , 1 );
- break;
- //Sinon, si c'est juste un 'Notice' (avertissement)
- case 8:
- case 1024:
- ecriture_base( $date , $errno , $errmsg , $errfichier , $errligne , 2 );
- break;
- }
- }
-
- //toutes les erreurs doivent être reportées
- error_reporting( E_ALL );
- //Quand on rencontre une erreur, on appelle la fonction erreurphp()
- $error_handler = set_error_handler("erreurphp");
-
- //La fonction qui écrit dans le fichier
- function ecriture_base( $date , $errno , $errmsg , $errfichier, $errligne, $type_erreur){
-
- //Connexion à la base de donnée
- include ("config/sql.inc.php");
- $connexion_db = mysql_connect("$host","$login","$pass");
- mysql_select_db("$bdd","$connexion_db");
-
- //Enregistrement des données en base
- $sql = "INSERT INTO $table_erreur (date,errno,errmsg,errfichier,errligne,type_erreur) VALUES('$date','$errno,'$errmsg','$errfichier','$errligne','$type_erreur')";
- mysql_query($sql);
-
- //fermeture connexion à la base de donnée
- mysql_close($connexion_db);
- }
-
- ?>
<?php
function erreurphp( $errno , $errmsg , $errfichier , $errligne , $errcontext ){
$date = date( 'd/m/Y H:i:s' );
switch( $errno ){
//gestion des erreurs importantes
case 1:
case 16:
case 64:
case 256:
//Enregistrement de l'erreur
ecriture_base( $date , $errno , $errmsg , $errfichier , $errligne , 0 );
//arret du script
die( 'Erreur : Rééssayez plus tard.' );
//Gestion des erreurs moyennement importantes
case 2:
case 4:
case 32:
case 128:
case 512:
//Enregistrement de l'erreur
ecriture_base( $date , $errno , $errmsg , $errfichier , $errligne , 1 );
break;
//Sinon, si c'est juste un 'Notice' (avertissement)
case 8:
case 1024:
ecriture_base( $date , $errno , $errmsg , $errfichier , $errligne , 2 );
break;
}
}
//toutes les erreurs doivent être reportées
error_reporting( E_ALL );
//Quand on rencontre une erreur, on appelle la fonction erreurphp()
$error_handler = set_error_handler("erreurphp");
//La fonction qui écrit dans le fichier
function ecriture_base( $date , $errno , $errmsg , $errfichier, $errligne, $type_erreur){
//Connexion à la base de donnée
include ("config/sql.inc.php");
$connexion_db = mysql_connect("$host","$login","$pass");
mysql_select_db("$bdd","$connexion_db");
//Enregistrement des données en base
$sql = "INSERT INTO $table_erreur (date,errno,errmsg,errfichier,errligne,type_erreur) VALUES('$date','$errno,'$errmsg','$errfichier','$errligne','$type_erreur')";
mysql_query($sql);
//fermeture connexion à la base de donnée
mysql_close($connexion_db);
}
?>
Sources de la même categorie
Commentaires et avis
|
Derniers Blogs
ZUNE : NOUVELLE VERSION DU ZUNE SOFTWARE - V 4.2ZUNE : NOUVELLE VERSION DU ZUNE SOFTWARE - V 4.2 par ROMELARD Fabrice
Avec la dernière génération du lecteur MP3 de Microsoft, le ZUNE HD, Microsoft a publié une nouvelle version du logiciel pour PC. Ainsi, je me suis décidé à installer celle-ci sur mon Tablet PC ACER, comme toujours le logiciel est donc tél...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice L'INTERFACE NATURELLE DE WINDOWS PHONE 7 SERIESL'INTERFACE NATURELLE DE WINDOWS PHONE 7 SERIES par odewit
La tendance est aux interfaces naturelles (NUI), et le keynote de Bill Buxton au MIX l'a bien souligné.
La charte graphique et ergonomique de Windows Phone 7 a donc été entièrement repensée en vue d'obtenir un maximum d'efficacité sur ce point. En re...
Cliquez pour lire la suite de l'article par odewit COMMENT MAPPER UNE VUE SQL SUR UNE COLLECTION DE COMPLEX TYPE?COMMENT MAPPER UNE VUE SQL SUR UNE COLLECTION DE COMPLEX TYPE? par Matthieu MEZIL
Avec EF, les vues doivent être mappées sur des entity types. Le problème c'est que les entity types doivent avoir une clé. Avec EF, nous avons les complex type qui n'ont pas de clé mais les vues ne peuvent pas être mappées dessus. Avec EF4, il est possibl...
Cliquez pour lire la suite de l'article par Matthieu MEZIL
Logiciels
Academy System (10.9.4.0)ACADEMY SYSTEM (10.9.4.0)Logiciel de gestion des établissements.
- élèves/étudiants (inscription, dossier, absence...)
-... Cliquez pour télécharger Academy System Xilisoft Convertisseur Vidéo Ultimate (5.1.39.0305)XILISOFT CONVERTISSEUR VIDéO ULTIMATE (5.1.39.0305)Xilisoft Convertisseur Vidéo Ultimate est un outil puissant de conversion vidéo, facile à utilise... Cliquez pour télécharger Xilisoft Convertisseur Vidéo Ultimate Xilisoft DVD Ripper Ultimate (5.0.64.0304)XILISOFT DVD RIPPER ULTIMATE (5.0.64.0304)Xilisoft DVD Ripper Ultimate est un logiciel excellent pour copier et convertir DVD vers presque ... Cliquez pour télécharger Xilisoft DVD Ripper Ultimate Rigs of Rods (63.3)RIGS OF RODS (63.3)c'est un jeu de multi-simulation camions,autobus voitures, avions, bateaux, hélicoptère avec défo... Cliquez pour télécharger Rigs of Rods
|