SLF4J 记录器不向控制台打印任何内容
SLF4J logger does not print anything to console
我想使用 AspectJ 和 Slf4j 将日志添加到我的 Java 应用程序中。基本上,方面只是以这种方式委托给 slf4j 方法:
package my.domain.com;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public aspect MyAspectLogger {
private Logger logger;
public MyAspectLogger() {
this.logger = LoggerFactory.getLogger( "MyAspectLogger" );
}
pointcut callSomeFunction(): call(* de.my.domain.MyClass.*());
before() : callSomeFunction() {
logger.error( "**** (Before) Called something in MyClass ****" );
}
after() : callSomeFunction() {
System.out.println( "**** (After) Called something in MyClass ****" );
}
}
为什么System.out.println()
打印信息,而logger.error()
不打印信息?
您应该确保在类路径上有像 logback 这样的 SLF4J 实现。
我想使用 AspectJ 和 Slf4j 将日志添加到我的 Java 应用程序中。基本上,方面只是以这种方式委托给 slf4j 方法:
package my.domain.com;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public aspect MyAspectLogger {
private Logger logger;
public MyAspectLogger() {
this.logger = LoggerFactory.getLogger( "MyAspectLogger" );
}
pointcut callSomeFunction(): call(* de.my.domain.MyClass.*());
before() : callSomeFunction() {
logger.error( "**** (Before) Called something in MyClass ****" );
}
after() : callSomeFunction() {
System.out.println( "**** (After) Called something in MyClass ****" );
}
}
为什么System.out.println()
打印信息,而logger.error()
不打印信息?
您应该确保在类路径上有像 logback 这样的 SLF4J 实现。