Files
java-tutorials/spring-mvc-java/src/main/java/com/baeldung/aop/LoggingAspect.java
T

55 lines
1.6 KiB
Java
Raw Normal View History

2016-04-07 06:17:57 -05:00
package com.baeldung.aop;
2015-12-03 13:46:25 +03:00
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.aspectj.lang.annotation.Pointcut;
import org.springframework.stereotype.Component;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.logging.Logger;
@Component
@Aspect
public class LoggingAspect {
private static Logger logger = Logger.getLogger(LoggingAspect.class.getName());
private ThreadLocal<SimpleDateFormat> sdf = new ThreadLocal<SimpleDateFormat>() {
@Override
protected SimpleDateFormat initialValue() {
return new SimpleDateFormat("[yyyy-mm-dd hh:mm:ss:SSS]");
}
};
@Pointcut("@target(org.springframework.stereotype.Repository)")
2016-01-30 12:01:41 +02:00
public void repositoryMethods() {
}
2015-12-03 13:46:25 +03:00
2016-04-07 06:17:57 -05:00
@Pointcut("@annotation(com.baeldung.aop.annotations.Loggable)")
2016-01-30 12:01:41 +02:00
public void loggableMethods() {
}
2015-12-06 18:44:56 +03:00
2016-04-07 06:17:57 -05:00
@Pointcut("@args(com.baeldung.aop.annotations.Entity)")
2016-01-30 12:01:41 +02:00
public void methodsAcceptingEntities() {
}
2015-12-06 18:44:56 +03:00
2015-12-03 13:46:25 +03:00
@Before("repositoryMethods()")
2015-12-06 18:44:56 +03:00
public void logMethodCall(JoinPoint jp) {
2015-12-03 13:46:25 +03:00
String methodName = jp.getSignature().getName();
logger.info(sdf.get().format(new Date()) + methodName);
}
2015-12-06 18:44:56 +03:00
@Before("loggableMethods()")
public void logMethod(JoinPoint jp) {
String methodName = jp.getSignature().getName();
logger.info("Executing method: " + methodName);
}
@Before("methodsAcceptingEntities()")
public void logMethodAcceptionEntityAnnotatedBean(JoinPoint jp) {
logger.info("Accepting beans with @Entity annotation: " + jp.getArgs()[0]);
}
2015-12-03 13:46:25 +03:00
}