是否可以通过slf4j包装记录器?
例如,在调试模式下,当我检查org.slf4j.LoggerFactory.getLogger(loggerName)
时,我可以看到记录器(此处为java.util.logging
):
我想做类似的事情:
// Get the real logger, cast in java.util.logging
java.util.logging.Logger myLogger = LoggerFactory.getLogger(loggerName))...;
// Use the java.util.logging methods
myLogger.setLevel(Level.parse(level));
答案 0 :(得分:8)
我找到了使用反射的解决方案。 在slf4j Logger中查找“logger”字段。
private <T> T getLogger(final String loggerName, final Class<T> loggerClass) {
final org.slf4j.Logger logger = LoggerFactory.getLogger(loggerName);
try {
final Class<? extends org.slf4j.Logger> loggerIntrospected = logger.getClass();
final Field fields[] = loggerIntrospected.getDeclaredFields();
for (int i = 0; i < fields.length; i++) {
final String fieldName = fields[i].getName();
if (fieldName.equals("logger")) {
fields[i].setAccessible(true);
return loggerClass.cast(fields[i].get(logger));
}
}
} catch (final Exception e) {
logger.error(e.getMessage());
}
return null;
}
致电:
java.util.logging.Logger myLogger = getLogger(loggerName, java.util.logging.Logger.class)
// or
org.apache.log4j.Logger myLogger = getLogger(loggerName, org.apache.log4j.Logger.class)
但使用slf4j API可能存在更好的解决方案吗?
答案 1 :(得分:0)
为了找到 slf4j 使用的实现(例如,像 spring-boot 中的 logback/log4j),您可以使用以下方法提取该信息
System.out.println(StaticLoggerBinder.getSingleton().getLoggerFactory());
输出
ch.qos.logback.classic.LoggerContext[default]