gpt4 book ai didi

java - Spring AOP不调用拦截器

转载 作者:行者123 更新时间:2023-12-01 06:04:34 25 4
gpt4 key购买 nike

我是 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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com