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

Java Discussion :

[Log4J] Récupérer la sortie standard d'une classe appellée


Sujet :

Java

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2003
    Messages : 11
    Points : 11
    Points
    11
    Par défaut [Log4J] Récupérer la sortie standard d'une classe appellée
    Bonjour,

    Dans mon projet j'utilise une librairie (.jar) avec des classes qui font joyeusement du "System.out.println(...)" un peu partout... Ce qui me gène car dand le projet je gère tous mes logs avec Log4j!

    Evidemment je n'ai pas la possibilité de modifier le code de ces classes (techniquement je pourrais décompiler, mais je n'en n'ai pas le droit :-) Et puis ça compliquerait l'installation de futures versions de cette lib...). Du coup je voulais savoir s'il était possible de récupérer la sortie standard de ces classes et de les injecter dans mes logger afin qu'elle s'affiche dans le bon fichier de log avec le bon format...

    D'avance merci!

  2. #2
    Membre expert

    Homme Profil pro
    Consultant informatique
    Inscrit en
    Janvier 2004
    Messages
    2 301
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2004
    Messages : 2 301
    Points : 3 675
    Points
    3 675
    Par défaut
    y'a toujours System.setOut, mais ça agit sur toute la VM...
    "Le plug gros problème des citations trouvées sur internet, c'est qu'on ne peut jamais garantir leur authenticité"

    Confucius, 448 av. J-C

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2003
    Messages : 11
    Points : 11
    Points
    11
    Par défaut
    Oui et puis System.out me redirige l'outstream vers un fichier en particulier sans passer par Log4j. Mais j'ai vraiment besoin que ce soit pris en charge par Log4j afin que je puisse contrôler le format du log au final. Mais merci quand même ;-)

  4. #4
    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 Pill_S Voir le message
    y'a toujours System.setOut, mais ça agit sur toute la VM...
    La réponse se trouve effectivement dans le setOut mais pas uniquement il faut que tu fasses ton propre OutputStream. Ceux qui souhaites rediriger le flux standard vers un JTextArea ont exactement le même problème.
    Si tu veux un exemple c'est ici.

    De plus, n'oublie pas qu'il y as aussi le System.err que tu peux rediriger avec System.setErr.
    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

  5. #5
    Membre expert

    Homme Profil pro
    Consultant informatique
    Inscrit en
    Janvier 2004
    Messages
    2 301
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2004
    Messages : 2 301
    Points : 3 675
    Points
    3 675
    Par défaut
    ... le problème est que cela agit pour TOUS les System.out.xxx.

    Le Monsieur ne veut rediriger que certains de ces appels...


    "Le plug gros problème des citations trouvées sur internet, c'est qu'on ne peut jamais garantir leur authenticité"

    Confucius, 448 av. J-C

Discussions similaires

  1. Réponses: 1
    Dernier message: 11/06/2008, 15h02
  2. Récupérer la sortie standard dans une autre classe
    Par EvilAngel dans le forum Entrée/Sortie
    Réponses: 2
    Dernier message: 22/12/2006, 17h15
  3. Recupération d'un sortie standard via une commande ssh.
    Par yanndan dans le forum Administration système
    Réponses: 1
    Dernier message: 28/08/2006, 16h56
  4. Réponses: 6
    Dernier message: 12/04/2006, 14h53
  5. Réponses: 7
    Dernier message: 08/01/2005, 13h24

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