private static final Logger logger = LoggerFactory.getLogger(TestSub1.class);
In diesem Fall ist die Beschreibung für jede Klassendatei unterschiedlich, und beim Kopieren ist Vorsicht geboten.
TestSample1.java
package test;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class TestSample1 {
private static final Logger logger = LoggerFactory.getLogger(TestSub1.class);
public void exec() {
logger.debug("Exec method was executed.");
}
}
private final Logger logger = LoggerFactory.getLogger(this.getClass());
Wenn Sie dies verwenden, können Sie es nicht "statisch" machen, aber Sie können es kopieren, da die Beschreibung in jeder Klassendatei gleich ist.
TestSample2.java
package test;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class TestSample2 {
private final Logger logger = LoggerFactory.getLogger(this.getClass());
public void exec() {
logger.debug("TestSample#Exec method was executed.");
}
}
private static final Logger logger = LoggerFactory.getLogger(Util.getClassName());
Mit der Methode "Util # getClassName" haben alle Klassendateien dieselbe Beschreibung und können kopiert werden. Es kann auch mit "statisch" verwendet werden.
TestSample3.java
package test;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class TestSample3 {
private static final Logger logger = LoggerFactory.getLogger(Util.getClassName());
public void exec() {
logger.debug("TestSample3#exec method was executed.");
}
}
Util.java
package test;
public class Util {
public static String getClassName() {
return Thread.currentThread().getStackTrace()[2].getClassName();
}
}
Es ist möglich, Instanzen mit "@ Produces" und "@ Inject" in "Logger" zu injizieren. Alle Klassendateien haben dieselbe Beschreibung und können kopiert werden.
SampleManagedBean.java
package test.mb;
import java.io.Serializable;
import javax.enterprise.context.SessionScoped;
import javax.inject.Inject;
import javax.inject.Named;
import org.slf4j.Logger;
@Named
@SessionScoped
public class SampleManagedBean implements Serializable {
private static final long serialVersionUID = 1L;
@Inject
private transient Logger logger;
public String execute() {
logger.info("SampleManagedBean#execute method was executed.");
return null;
}
}
LoggerFactoryProducer.java
package test.util;
import javax.enterprise.context.Dependent;
import javax.enterprise.inject.Produces;
import javax.enterprise.inject.spi.InjectionPoint;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
@Dependent
public class LoggerFactoryProducer {
@Produces
public Logger getLogger(InjectionPoint ip) {
return LoggerFactory.getLogger(ip.getMember().getDeclaringClass().getName());
}
}
das ist alles