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 :

[Log4J] Récupérer StackTrace


Sujet :

Logging Java

  1. #1
    Membre à l'essai
    Inscrit en
    Février 2010
    Messages
    18
    Détails du profil
    Informations forums :
    Inscription : Février 2010
    Messages : 18
    Points : 18
    Points
    18
    Par défaut [Log4J] Récupérer StackTrace
    Salut,

    Question surement "bête" mais est-il possible de "récupérer" la StackTrace sans passer par un "log.LEVEL('mon message')" ?
    En fait je veux récupérer la console dans mon fichier de log !

    Merci d'avance.

  2. #2
    Membre à l'essai
    Inscrit en
    Février 2010
    Messages
    18
    Détails du profil
    Informations forums :
    Inscription : Février 2010
    Messages : 18
    Points : 18
    Points
    18
    Par défaut UP
    En fait, je veux "juste" récupérer tout ce qui s'écrit dans la console (les exceptions) dans mon fichier de log.

    Sans avoir modifier mes classes et rajouter un log.ERROR("Error"), en plus du trhow new Exception("Error")

  3. #3
    Modérateur
    Avatar de Alkhan
    Homme Profil pro
    ingénieur full stack
    Inscrit en
    Octobre 2006
    Messages
    1 232
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : ingénieur full stack

    Informations forums :
    Inscription : Octobre 2006
    Messages : 1 232
    Points : 2 061
    Points
    2 061
    Par défaut
    bonjour,
    Citation Envoyé par bdubain Voir le message
    En fait, je veux "juste" récupérer tout ce qui s'écrit dans la console (les exceptions) dans mon fichier de log.
    Pour cela il faut utiliser un ConsoleApender
    Il n'y a pas de problème, il n'y a que des solutions.
    Cependant, comme le disaient les shadoks, s'il n'y a pas de solution, c'est qu'il n'y a pas de problème.
    Si toutefois le problème persiste, la seule solution restante est de changer le périphérique qui se trouve entre la chaise et l'écran

    Mes Articles : Mon premier article est sur le language D
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  4. #4
    Membre à l'essai
    Inscrit en
    Février 2010
    Messages
    18
    Détails du profil
    Informations forums :
    Inscription : Février 2010
    Messages : 18
    Points : 18
    Points
    18
    Par défaut
    Merci pour ta réponse;

    J'ai déjà un appender (RollingFile).

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    <appender name="fileinfo" class="org.apache.log4j.RollingFileAppender">
    	     <param name="file" value="monLog.log"/>
    	     <param name="append" value="true" />
    	     <param name="encoding" value="UTF-8" />
    	     <param name="MaxFileSize" value="1MB"/>
    	     <param name="MaxBackupIndex" value="20"/>
    	     <layout class="org.apache.log4j.PatternLayout">
    		 	<param name="ConversionPattern" value="%d{dd-MM-yyyy HH:mm:ss} %-5p : %m%n" />
    		</layout>
    	     <filter class="org.apache.log4j.varia.LevelRangeFilter">
    	         <param name="levelMin" value="INFO"/>
    	         <param name="levelMax" value="FATAL"/>
    	     </filter>
    	 </appender>
    Mais il n'écrit rien à part les logs de démarrage du serveur (Tomcat).
    Il faut que je passe par un logger dans toutes les classes et faire un logger.Level(e.getMessage()), mais je voudrais éviter ça.

  5. #5
    Modérateur
    Avatar de Alkhan
    Homme Profil pro
    ingénieur full stack
    Inscrit en
    Octobre 2006
    Messages
    1 232
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : ingénieur full stack

    Informations forums :
    Inscription : Octobre 2006
    Messages : 1 232
    Points : 2 061
    Points
    2 061
    Par défaut
    Oups !
    je n'étais pas réveillé quand j'ai lus ton post

    En fait, il faut que tu redirige la sortie standard et la sorite erreur !
    Pour cela tu dois créer ton propre outputstream dédié pour les logs !

    Ensuite tu dois redirigé les sortie vers ton outputstream avec System.setOut et System.setErr et le tour est joué

    Un exemple ici qui correspond exactement a ce qu'il te faut
    Il n'y a pas de problème, il n'y a que des solutions.
    Cependant, comme le disaient les shadoks, s'il n'y a pas de solution, c'est qu'il n'y a pas de problème.
    Si toutefois le problème persiste, la seule solution restante est de changer le périphérique qui se trouve entre la chaise et l'écran

    Mes Articles : Mon premier article est sur le language D
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  6. #6
    Membre à l'essai
    Inscrit en
    Février 2010
    Messages
    18
    Détails du profil
    Informations forums :
    Inscription : Février 2010
    Messages : 18
    Points : 18
    Points
    18
    Par défaut
    Merci beaucoup ! Je vais mettre ça en place

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

Discussions similaires

  1. Log4j commons logging ou stackTrace
    Par jicaygg dans le forum Logging
    Réponses: 4
    Dernier message: 20/05/2010, 10h30
  2. [Log4J] Récupérer la sortie standard d'une classe appellée
    Par luthier dans le forum Général Java
    Réponses: 4
    Dernier message: 15/04/2010, 17h22
  3. intégrité stacktrace : JBoss-log4j-syslog
    Par jarko dans le forum Administration système
    Réponses: 0
    Dernier message: 01/09/2009, 21h37
  4. Récupérer l'entier de stackTrace
    Par Baptiste Wicht dans le forum Général Java
    Réponses: 1
    Dernier message: 24/04/2007, 23h52

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