我正在使用 Spring AOP 和 Log4J 将记录器作为方面实现,但我注意到日志文件中的类名始终是LoggerAspect
类名,所以......有没有办法在我的日志中跟踪实际的类名?
问问题
13670 次
3 回答
15
@Around("execution(* com.mycontrollerpackage.*.*(..))")
public Object aroundWebMethodE(ProceedingJoinPoint pjp) throws Throwable {
String packageName = pjp.getSignature().getDeclaringTypeName();
String methodName = pjp.getSignature().getName();
long start = System.currentTimeMillis();
if(!pjp.getSignature().getName().equals("initBinder")) {
logger.info("Entering method [" + packageName + "." + methodName + "]");
}
Object output = pjp.proceed();
long elapsedTime = System.currentTimeMillis() - start;
if(!methodName.equals("initBinder")) {
logger.info("Exiting method [" + packageName + "." + methodName + "]; exec time (ms): " + elapsedTime);
}
return output;
}
于 2012-07-16T14:22:36.373 回答
11
这更容易:
pjp.getTarget().getClass()
于 2012-08-17T15:42:34.923 回答
4
使用:pjp.getTarget().getClass().getCanonicalName()
此外,要在执行哪个方法的类级别添加日志,而不是使用建议类的记录器,请在建议方法中使用类级别记录器,如下所示
Logger logger = Logger.getLogger(pjp.getTarget().getClass().getCanonicalName());
于 2018-03-23T07:33:58.253 回答