12

Spring AOPとLog4Jを使用してアスペクト指向としてロガーを実装していますが、ログファイルのクラス名は常にクラス名であることに気づきました。ログ内LoggerAspectの実際のクラス名を追跡する方法はありますか。 ?

4

3 に答える 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 に答える