我正在使用 Spring AOP 和 Log4J 将记录器作为一个方面来实现,但我注意到日志文件中的类名始终是 LoggerAspect 类名,所以......有没有办法在我的日志?

最佳答案

@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;
}

关于java - Log4j 和 AOP,如何获取实际的类名,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/11505735/

10-15 11:09