Log4j and AOP, how to get actual class name

后端 未结 3 1095
再見小時候
再見小時候 2021-02-05 19:59

I\'m implementing a logger as an aspect using Spring AOP and Log4J, but I\'ve noticed that the class name in log file is always the LoggerAspect class name, so... i

相关标签:
3条回答
  • 2021-02-05 20:14
    @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;
    }
    
    0 讨论(0)
  • 2021-02-05 20:17

    this is easier:

    pjp.getTarget().getClass()
    
    0 讨论(0)
  • 2021-02-05 20:28

    Use : pjp.getTarget().getClass().getCanonicalName()

    Also, to add logs at class level of which method is being exexuted instead using logger of advice class, use class level logger within advice method, as below

    Logger logger = Logger.getLogger(pjp.getTarget().getClass().getCanonicalName());
    
    0 讨论(0)
提交回复
热议问题