Spring AOP - 方面不拦截任何东西

Spring AOP - Aspect doesn't intercept anything

pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.8.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>...</groupId>
    <artifactId>...</artifactId>
    <version>1.0.0-SNAPSHOT</version>
    <name>...</name>
    <description>...</description>

    <properties>
        <java.version>11</java.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
            <version>2.1.8.RELEASE</version>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-aop</artifactId>
            <version>2.1.8.RELEASE</version>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>  

Application.java

@SpringBootApplication
public class Application implements CommandLineRunner {
    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }

    @Override
    public void run(String... args) throws Exception {
        new Test().test();
    }
}  

Test.java

public class Test {
    public void test() {
        System.out.println("TEST");
    };
}

Aspect.java

import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;

@Aspect
@Component
public class Aspect {
    @Around("execution(* Test.*(..))")
    public Object test(ProceedingJoinPoint joinPoint) throws Throwable {
        System.out.println("Aspect: " + joinPoint.getSignature().getName());
        return joinPoint.proceed();
    }
}

我想我 post 都读完了!告诉我是否缺少某些东西。

我在看点的方法测试下了断点,没有。他的默认构造函数在 Spring 初始化期间被调用,因此当上下文启动时他被正确初始化。

我不知道为什么,但 Aspect 没有拦截任何东西。我尝试了不同的切入点,特别是我需要拦截带有一些自定义异常的自定义注释,我在这里将代码简化为post。

无论如何,即使 运行 我无法从 Aspect.java[=54 中获取 System.out.println 放在 test() 方法中的代码=] class.

编译过程就好了。甚至 运行 应用程序都可以正常工作,除了这个。

我正在使用 IntelliJ IDEA,我不知道这是否会在某些情况下干扰编织过程。

但也许错误比我想象的更愚蠢。

谢谢。

尝试在@Around 注释中添加完整包:

@Around("execution(* com.mysite.mypackage.Test.*(..))")

Spring AOP 只能为Spring 组件创建代理并为其添加切面拦截器(通知)。您的 class Test 不是 @Component,我没有看到任何配置从中创建 Spring bean。