java - Spring AOP不调用拦截器

标签 java spring aspectj

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

相关文章:

java - AspectJ 可以与 Java 7 一起使用吗?

javascript - 如何使用 javaScript 获取从 java 类传递到 native 脚本 jar 文件的变量数据

java - 提取字符串

java - 如何在线程中注入(inject)Spring Bean

java - 为什么匿名类方法调用方法时aop无法执行?

java - 使用类级别注释(aspectj)审核类的字段

java - 在 java servlet 应用程序中执行异步数据库任务

Java Web Launch 兑现第二个 JNLP 文件运行

java - HttpMessageConversionException 中的 UnrecognizedPropertyException 未在 ControllerAdvice 中展开

java - 从字符串加载 spring 应用程序上下文