IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Logging Java Discussion :

Ajouter la date avant une exception affichée sur la sortie d'erreur


Sujet :

Logging Java

  1. #1
    Membre averti
    Avatar de Heavy Metal Hero
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2007
    Messages
    152
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Juin 2007
    Messages : 152
    Points : 333
    Points
    333
    Billets dans le blog
    13
    Par défaut Ajouter la date avant une exception affichée sur la sortie d'erreur
    Bonsoir,
    Dans mon application, j'utilise log4j. Tous les logs sont écrits dans un fichier, mais si une erreur de type STDERR n'étant pas gérée par mes logs survient, elle est redirigée dans un autre fichier. Par exemple, une NullPointerException ne va pas passer par mes logs mais être directement redirigée sur la sortie d'erreur, donc mon deuxième fichier.

    Je dois ajouter l'heure avant l'exception. J'ai utilisé un PrintStream personnalisé pour ça:

    Main.java

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    public class Main {
        MyPrintStream ps;
     
        public static void main(String[] args) {
            System.setErr(new MyPrintStream(System.out));
            Integer i = null;
            String str = i.toString();
        }
    }
    MyPrintStream.java

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    public class MyPrintStream extends PrintStream {
        public MyPrintStream(OutputStream out) {
            super(out);
        }
     
        @Override
        public void println(String string) {
            Date date = new Date();
            SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS");
            super.println(simpleDateFormat.format(date) + " " + string);
        }
    }
    Output:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    Exception in thread "main" java.lang.NullPointerException
    2018-03-21 18:05:53.749     at test.Main.main(Main.java:9)
    Ce dont j'ai besoin:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    2018-03-21 18:05:53.749 Exception in thread "main" java.lang.NullPointerException
     at test.Main.main(Main.java:9)
    Dans ma sortie, la date est affichée pour chaque ligne sauf la première. Si je surcharge la méthode print(), alors je me retrouve avec la date 3 fois inscrite au début et au milieu de l'exception.
    Comment n'afficher la date qu'une seule fois, au début de l'exception ?

    Une autre solution est possible, c'est d'afficher un log via log4j à chaque fois qu'une exception non gérée arrive, mais je ne sais pas comment faire si l'exception n'est pas catchée...

  2. #2
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Salut,

    Tu pourrais simplement faire un appender log4j vers lequel rediriger "stderr", et tes fichiers auraient la même forme.

    Éventuellement pour faire ce que tu dis (ajouter une date sur les erreurs non catchées), tu dates dans le UncaughtExceptionHandler :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    public static void main(String[] args) {
     
     
    		Thread.currentThread().setUncaughtExceptionHandler(new UncaughtExceptionHandler() {
     
    	        SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS");
    			@Override
    			public void uncaughtException(Thread t, Throwable e) {
    				Date date = new Date(); // faire le new Date() ici, en dehors du block, garanti d'avoir une heure au plus juste, mais les traces pourraient être au final dans le désordre dans le fichier
    		        synchronized (System.err) {
    		           System.err.print(simpleDateFormat.format(date) );
                               System.err.print(" Exception in thread \""+t.getName()+"\" "); 
    		           e.printStackTrace(System.err);
    		        }
    		     }
    		});
     
    		Integer i = null;
            String str = i.toString();
     
    	}
    Tu peux rediriger le System.err vers un fichier en plus si tu veux.
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  3. #3
    Membre averti
    Avatar de Heavy Metal Hero
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2007
    Messages
    152
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Juin 2007
    Messages : 152
    Points : 333
    Points
    333
    Billets dans le blog
    13
    Par défaut
    Ok pas mal ça merci !

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Comment afficher sur la sortie standard ?
    Par cranama dans le forum C
    Réponses: 8
    Dernier message: 31/12/2007, 14h44
  2. Réponses: 2
    Dernier message: 02/07/2007, 15h05
  3. Afficher des lignes d'avant une date
    Par grenoult dans le forum Requêtes
    Réponses: 4
    Dernier message: 12/12/2006, 07h55
  4. ajout ou remplacement d'une barette RAM sur un portable
    Par kenny49 dans le forum Composants
    Réponses: 3
    Dernier message: 10/08/2006, 13h32
  5. Réponses: 7
    Dernier message: 29/05/2006, 14h46

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo