Die Anleitung zu Java Commons Logging
1. Was ist Commons Logging?
Möchten Sie in Ihrer Applikation Java die Code schreiben, um während ihres Arbeitensprozess die Nachricht der Applikation aufzuschreiben? Sie können eine der 3 folgenden Bibliothek Logger verwenden:
- Log4J Logger
- Jdk14 Logger
- Simple Logger
Commons Logging ist einer Bibliothek, Ihnen mit einer der 3 oben Bibliothek einfacher arbeiten zu lassen. So kann es kein Logger sein, um ein Log Programm zu schreiben. Wie Sie mit java.io für Umgang mit der Datei arbeiten, ist Commons IO eine auf java.io geschriebene Bibliothek um Ihnen bei der einfacheren Behandlung von IO zu unterstützen. Commons IO kann java.io nicht ersetzen
So haben Sie 3 Wähle:
Es ist nicht wichtig, welche Logger gewählt wird. Sie wird mit der Hilfe von Commons Logging miteinander ähnlich behandelt.
2. Das Ziel von der Anleitung
In diesem Unterlagen werde ich Ihnen den Umgang mit ... führen:
- Commons Logging + Log4J Logger
3. Commons Logging + Log4J Logger
Die Bibliothek (Library)
Die Bibliothek Commons Logging:
Maven:
<dependency>
<groupId>commons-logging</groupId>
<artifactId>commons-logging</artifactId>
<version>1.1.3</version>
</dependency>
Die Bibliothek Log4J Logger:
Maven:
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
Das Projekt erstellen
pom.xml
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>org.o7planning</groupId>
<artifactId>CommonsLoggingTutorial</artifactId>
<version>0.0.1-SNAPSHOT</version>
<dependencies>
<dependency>
<groupId>commons-logging</groupId>
<artifactId>commons-logging</artifactId>
<version>1.1.3</version>
</dependency>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
</dependencies>
</project>
Das einfache Beispiel HelloWorld (In dem Bildschirm Console log)
In diesem Schritt machen wir ein einfaches Beispiel HelloWorld, das schreibt Log in dem Bildschirm Console.
HelloWorld.java
package org.o7planning.tutorial.commonslogging;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
public class HelloWorld {
private static final Log log = LogFactory.getLog(HelloWorld.class);
public static void main(String[] args) {
log.debug("Example debug message ..");
log.info("Example info message ..");
log.warn("Example warn message ..");
log.error("Example error message ..");
log.fatal("Example fatal message ..");
}
}
commons-logging.properties
org.apache.commons.logging.Log=org.apache.commons.logging.impl.Log4JLogger
log4j.configuration=log4j.properties
log4j.properties
log4j.rootLogger=DEBUG, CA, NTEventLog
#Console Appender
log4j.appender.CA=org.apache.log4j.ConsoleAppender
log4j.appender.CA.layout=org.apache.log4j.PatternLayout
log4j.appender.CA.layout.ConversionPattern=%-4r [%t] %-5p %c %x - %m%n
In der Praxis können Sie die Commons Logging konfigurieren um die anderen Bibliothek Logging zu benutzen, kein log4j:
Starten Sie die class HelloWorld:
Mit Log4j können Sie auf die File xml konfigurieren und die Konfiguration auf die File xml ist einfacher und mehr verständlich als Properties.
Öffnen Sie die File commons-logging.properties und dazu ändern:
commons-logging.properties
org.apache.commons.logging.Log=org.apache.commons.logging.impl.Log4JLogger
log4j.configuration=log4j.xml
log4j.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
<appender name="MyConsole" class="org.apache.log4j.ConsoleAppender">
<param name="Target" value="System.out" />
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%-4r [%t] %-5p %c %x - %m%n" />
</layout>
</appender>
<root>
<priority value="debug" />
<appender-ref ref="MyConsole" />
</root>
</log4j:configuration>
Starten Sie die Class HelloWorld und Log aufs Bildschirm Console sehen.
Das mehr komplizierte Beispiel (Log in die File aufschreiben)
Nächste führt wir ein mehr kompliziertes Beispiel durch. Das ist : Log in die File aufschreiben.
AdminApplication.java
package org.o7planning.tutorial.commonslogging.admin;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
public class AdminApplication {
private static final Log log = LogFactory.getLog(AdminApplication.class);
public static void main(String[] args) {
log.debug("Example debug message ..");
log.info("Example info message ..");
log.warn("Example warn message ..");
log.error("Example error message ..");
log.fatal("Example fatal message ..");
try {
raiseException();
} catch (Exception e) {
log.fatal("<Some Object>", e);
}
}
private static void raiseException() throws Exception {
throw new Exception("Test Exception");
}
}
FrontEndApplication.java
package org.o7planning.tutorial.commonslogging.frontend;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
public class FrontEndApplication {
private static final Log log = LogFactory.getLog(FrontEndApplication.class);
public static void main(String[] args) {
log.debug("Example debug message ..");
log.info("Example info message ..");
log.warn("Example warn message ..");
log.error("Example error message ..");
log.fatal("Example fatal message ..");
}
}
in log4j.xml konfigurieren, in die Konfiguration zusätzen
<appender name="AdminFileAppender" class="org.apache.log4j.FileAppender">
<param name="File" value="logs/admin.log" />
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern"
value="%d{dd MMM yyyy HH:mm:ss,SSS} {%t} %-5p %c %x - %m%n" />
</layout>
</appender>
<appender name="FrontEndFileAppender" class="org.apache.log4j.FileAppender">
<param name="File" value="logs/frontEnd.log" />
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern"
value="%d{dd MMM yyyy HH:mm:ss,SSS} {%t} %-5p %c %x - %m%n" />
</layout>
</appender>
<!-- logger name must by package name! -->
<logger name="org.o7planning.tutorial.commonslogging.admin">
<level value="ERROR" />
<appender-ref ref="AdminFileAppender" />
</logger>
<!-- logger name must by package name! -->
<logger name="org.o7planning.tutorial.commonslogging.frontend">
<level value="DEBUG" />
<appender-ref ref="FrontEndFileAppender" />
</logger>
log4j.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
<appender name="MyConsole" class="org.apache.log4j.ConsoleAppender">
<param name="Target" value="System.out" />
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%-4r [%t] %-5p %c %x - %m%n" />
</layout>
</appender>
<appender name="AdminFileAppender" class="org.apache.log4j.FileAppender">
<param name="File" value="logs/admin.log" />
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern"
value="%d{dd MMM yyyy HH:mm:ss,SSS} {%t} %-5p %c %x - %m%n" />
</layout>
</appender>
<appender name="FrontEndFileAppender" class="org.apache.log4j.FileAppender">
<param name="File" value="logs/frontEnd.log" />
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern"
value="%d{dd MMM yyyy HH:mm:ss,SSS} {%t} %-5p %c %x - %m%n" />
</layout>
</appender>
<!-- logger name must by package name! -->
<logger name="org.o7planning.tutorial.commonslogging.admin">
<level value="ERROR" />
<appender-ref ref="AdminFileAppender" />
</logger>
<!-- logger name must by package name! -->
<logger name="org.o7planning.tutorial.commonslogging.frontend">
<level value="DEBUG" />
<appender-ref ref="FrontEndFileAppender" />
</logger>
<root>
<priority value="debug" />
<appender-ref ref="MyConsole" />
</root>
</log4j:configuration>
Es gibt eine Achtung über die Reihenfolge der Karten wenn Sie log4j.xml:konfigurieren
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
<!-- render -->
<renderer></renderer>
<renderer></renderer>
<renderer></renderer>
<!-- appender -->
<appender></appender>
<appender></appender>
<appender></appender>
<!-- plugin -->
<plugin></plugin>
<plugin></plugin>
<plugin></plugin>
<!-- logger -->
<logger></logger>
<logger></logger>
<logger></logger>
<!-- category -->
<category></category>
<category></category>
<category></category>
<!-- root -->
<root></root>
<root></root>
<root></root>
<!-- loggerfactory -->
<loggerfactory></loggerfactory>
<loggerfactory></loggerfactory>
<loggerfactory></loggerfactory>
<!-- categoryfactory -->
<categoryfactory></categoryfactory>
<categoryfactory></categoryfactory>
<categoryfactory></categoryfactory>
</log4j:configuration>
Starten Sie die class AdminApplication:
Starten Sie die class FrontEndApplication
Ein Ordner logs wird erstellt und er hat 2 file log (admin.log & frontEnd.log).
Java Grundlagen
- Anpassen von Java-Compiler, der Ihre Annotation verarbeitet (Annotation Processing Tool)
- Java Programmierung für Team mit Eclipse und SVN
- Die Anleitung zu Java WeakReference
- Die Anleitung zu Java PhantomReference
- Komprimierung und Dekomprimierung in Java
- Konfigurieren von Eclipse zur Verwendung des JDK anstelle von JRE
- Java-Methoden String.format() und printf()
- Syntax und neue Funktionen in Java 8
- Die Anleitung zu Java Reguläre Ausdrücke
- Die Anleitung zu Java Multithreading Programming
- JDBC Driver Bibliotheken für verschiedene Arten von Datenbank in Java
- Die Anleitung zu Java JDBC
- Holen Sie sich die automatisch erhöhenden Wert der Spalte bei dem Insert eines Rekord, der JDBC benutzt
- Die Anleitung zu Java Stream
- Die Anleitung zu Java Functional Interface
- Einführung in Raspberry Pi
- Die Anleitung zu Java Predicate
- Abstrakte Klasse und Interface in Java
- Zugriffsmodifikatoren (Access modifiers) in Java
- Die Anleitung zu Java Enum
- Die Anleitung zu Java Annotation
- Vergleichen und Sortieren in Java
- Die Anleitung zu Java String, StringBuffer und StringBuilder
- Die Anleitung zu Java Exception
- Die Anleitung zu Java Generics
- Manipulieren von Dateien und Verzeichnissen in Java
- Die Anleitung zu Java BiPredicate
- Die Anleitung zu Java Consumer
- Die Anleitung zu Java BiConsumer
- Was ist erforderlich, um mit Java zu beginnen?
- Geschichte von Java und der Unterschied zwischen Oracle JDK und OpenJDK
- Installieren Sie Java unter Windows
- Installieren Sie Java unter Ubuntu
- Installieren Sie OpenJDK unter Ubuntu
- Installieren Sie Eclipse
- Installieren Sie Eclipse unter Ubuntu
- Schnelle lernen Java für Anfänger
- Geschichte von Bits und Bytes in der Informatik
- Datentypen in Java
- Bitweise Operationen
- if else Anweisung in Java
- Switch Anweisung in Java
- Schleifen in Java
- Die Anleitung zu Java Array
- JDK Javadoc im CHM-Format
- Vererbung und Polymorphismus in Java
- Die Anleitung zu Java Function
- Die Anleitung zu Java BiFunction
- Beispiel für Java Encoding und Decoding mit Apache Base64
- Die Anleitung zu Java Reflection
- Java-Remote-Methodenaufruf - Java RMI
- Die Anleitung zu Java Socket
- Welche Plattform sollten Sie wählen für Applikationen Java Desktop entwickeln?
- Die Anleitung zu Java Commons IO
- Die Anleitung zu Java Commons Email
- Die Anleitung zu Java Commons Logging
- Java System.identityHashCode, Object.hashCode und Object.equals verstehen
- Die Anleitung zu Java SoftReference
- Die Anleitung zu Java Supplier
- Java Aspect Oriented Programming mit AspectJ (AOP)
Show More
- Anleitungen Java Servlet/JSP
- Die Anleitungen Java Collections Framework
- Java API für HTML & XML
- Die Anleitungen Java IO
- Die Anleitungen Java Date Time
- Anleitungen Spring Boot
- Anleitungen Maven
- Anleitungen Gradle
- Anleitungen Java Web Services
- Anleitungen Java SWT
- Die Anleitungen JavaFX
- Die Anleitungen Oracle Java ADF
- Die Anleitungen Struts2 Framework
- Anleitungen Spring Cloud