log4j - Méthodes de journalisation
La classe Logger fournit une variété de méthodes pour gérer les activités de journalisation. La classe Logger ne nous permet pas d'instancier une nouvelle instance Logger mais elle fournit deux méthodes statiques pour obtenir un objet Logger -
- public static Logger getRootLogger();
- public static Logger getLogger(String name);
La première des deux méthodes renvoie le journal racine de l'instance d'application et elle n'a pas de nom.
Toute autre instance d'objet Logger nommée est obtenue via la deuxième méthode en transmettant le nom de l'enregistreur. Le nom de l'enregistreur peut être n'importe quelle chaîne que vous pouvez passer, généralement une classe ou un nom de package comme nous l'avons utilisé dans le dernier chapitre et il est mentionné ci-dessous -
static Logger log = Logger.getLogger(log4jExample.class.getName());
Méthodes de journalisation
Une fois que nous avons obtenu une instance d'un enregistreur nommé, nous pouvons utiliser plusieurs méthodes de l'enregistreur pour consigner les messages. La classe Logger dispose des méthodes suivantes pour imprimer les informations de journalisation.
# | Méthodes et description |
---|---|
1 | public void debug(Object message)
Il imprime les messages avec le niveau Level.DEBUG. |
2 | public void error(Object message)
Il imprime les messages avec le niveau Level.ERROR. |
3 | public void fatal(Object message)
Il imprime les messages avec le niveau Level.FATAL. |
4 | public void info(Object message)
Il imprime les messages avec le niveau Level.INFO. |
5 | public void warn(Object message)
Il imprime les messages avec le niveau Level.WARN. |
6 | public void trace(Object message)
Il imprime les messages avec le niveau Level.TRACE. |
Tous les niveaux sont définis dans le org.apache.log4j.Level class et l'une des méthodes mentionnées ci-dessus peuvent être appelées comme suit -
import org.apache.log4j.Logger;
public class LogClass {
private static org.apache.log4j.Logger log = Logger.getLogger(LogClass.class);
public static void main(String[] args) {
log.trace("Trace Message!");
log.debug("Debug Message!");
log.info("Info Message!");
log.warn("Warn Message!");
log.error("Error Message!");
log.fatal("Fatal Message!");
}
}
Lorsque vous compilez et exécutez LogClass programme, il générerait le résultat suivant -
Debug Message!
Info Message!
Warn Message!
Error Message!
Fatal Message!
Tous les messages de débogage ont plus de sens lorsqu'ils sont utilisés en combinaison avec des niveaux. Nous aborderons les niveaux dans le chapitre suivant et ensuite, vous aurez une bonne compréhension de la façon d'utiliser ces méthodes en combinaison avec différents niveaux de débogage.