log4j - Formatage du journal
Apache log4j fournit divers Layoutobjets, chacun pouvant formater les données de journalisation selon diverses dispositions. Il est également possible de créer un objet de mise en page qui formate les données de journalisation d'une manière spécifique à l'application.
Tous les objets de mise en page reçoivent un LoggingEvent objet du Appenderobjets. Les objets Layout récupèrent ensuite l'argument du message à partir de LoggingEvent et appliquent l'ObjectRenderer approprié pour obtenir la représentation String du message.
Les types de disposition
La classe de niveau supérieur de la hiérarchie est la classe abstraite org.apache.log4j.Layout. Il s'agit de la classe de base pour toutes les autres classes Layout de l'API log4j.
La classe Layout est définie comme abstraite dans une application, nous n'utilisons jamais cette classe directement; à la place, nous travaillons avec ses sous-classes qui sont les suivantes:
DateLayout
HTMLLayout
PatternLayout.
SimpleLayout
XMLLayout
Les méthodes de mise en page
Cette classe fournit une implémentation squelette de toutes les opérations courantes sur tous les autres objets Layout et déclare deux méthodes abstraites.
N ° Sr. | Méthodes et description |
---|---|
1 | public abstract boolean ignoresThrowable() Il indique si les informations de journalisation gèrent tout objet java.lang.Throwable qui lui est transmis dans le cadre de l'événement de journalisation. Si l'objet Layout gère l'objet Throwable, l'objet Layout ne l'ignore pas et renvoie false. |
2 | public abstract String format(LoggingEvent event) Les sous-classes de mise en page individuelles implémentent cette méthode pour le formatage spécifique à la mise en page. |
Outre ces méthodes abstraites, la classe Layout fournit une implémentation concrète des méthodes répertoriées ci-dessous:
N ° Sr. | Méthodes et description |
---|---|
1 | public String getContentType() Il renvoie le type de contenu utilisé par les objets Layout. La classe de base renvoie text / plain comme type de contenu par défaut. |
2 | public String getFooter() Il spécifie les informations de pied de page du message de journalisation. |
3 | public String getHeader() Il spécifie les informations d'en-tête du message de journalisation. |
Chaque sous-classe peut renvoyer des informations spécifiques à la classe en remplaçant l'implémentation concrète de ces méthodes.