我是 AspectJ 的新手,在阅读了此处的相关问题后,我仍然陷入困境。
我想使用 AspectJ 记录在指定包中运行方法调用所花费的时间。
我正在使用:spring-boot-starter-parent 版本 1.5.6.RELEASE
我添加了以下附加 Maven 依赖项:
<dependency
<groupId>org.aspectj</groupId>
<artifactId>aspectjweaver</artifactId>
<version>1.8.10</version>
</dependency>
<dependency>
<groupId>cglib</groupId>
<artifactId>cglib-nodep</artifactId>
<version>3.2.5</version>
</dependency>
我定义了一个配置类:
@Configuration
@EnableAspectJAutoProxy
@Aspect
public class PerformanceConfiguration {
@Bean
public PerformanceMonitorInterceptor performanceMonitorInterceptor() {
return new PerformanceMonitorInterceptor(true);
}
@Bean
public Advisor QuoteServiceImplMonitorAdvisor(PerformanceMonitorInterceptor performanceMonitorInterceptor) {
AspectJExpressionPointcut pointcut = new AspectJExpressionPointcut();
pointcut.setExpression("execution(* com.mycompany.*.*(..))");
return new DefaultPointcutAdvisor(pointcut, performanceMonitorInterceptor);
}
}
这是我的 logback.xml 文件:
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<property name="DEV_HOME" value="MyApplicationHome/logs" />
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>
%d{dd-MM-yyyy HH:mm:ss.SSS} %magenta([%thread]) %highlight(%-5level) %logger{36}.%M - %msg%n
</pattern>
</encoder>
</appender>
<appender name="FILE"
class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${DEV_HOME}/debug.log</file>
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<Pattern>
%d{yyyy-MM-dd HH:mm:ss} - %msg%n
</Pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- rollover daily -->
<fileNamePattern>${DEV_HOME}/archived/debug.%d{yyyy-MM-dd}.%i.log
</fileNamePattern>
<timeBasedFileNamingAndTriggeringPolicy
class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
<maxFileSize>10MB</maxFileSize>
</timeBasedFileNamingAndTriggeringPolicy>
</rollingPolicy>
</appender>
<logger name="log4j.logger.org.springframework.aop.interceptor.PerformanceMonitorInterceptor" level="TRACE">
<appender-ref ref="STDOUT"/>
</logger>
<root level="info">
<appender-ref ref="STDOUT"/>
<appender-ref ref="FILE"/>
</root>
</configuration>
我在控制台中没有看到任何跟踪条目,并且 PerformanceMonitorInterceptor 从未被调用。 有什么想法吗?
最佳答案
为什么你的配置类用@Aspect
注释?
@Aspect 应该位于 bean 类本身。
参见https://docs.spring.io/spring/docs/4.3.x/spring-framework-reference/html/aop.html#aop-at-aspectj
关于java - Spring AOP不调用拦截器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47585125/