Spring AOP-Aspect不会拦截任何内容

时间:2019-09-12 15:54:39

标签: java spring-boot aspectj spring-aop

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();
    }
}

我认为我发布了所有内容!告诉我是否缺少什么。

我在Aspect的方法测试中设置了一个断点,什么也没有。他的默认构造函数在Spring初始化期间被调用,因此在Context升高时可以正确地初始化他。

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

无论如何,即使运行这段代码,我也无法从 Aspect.java 类获得放置在System.out.println方法中的test()

编译过程很好。甚至运行该应用程序都可以正常运行,除此之外。

我正在使用IntelliJ IDEA,如果在某些情况下会干扰我所不知道的编织过程。

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

谢谢。

2 个答案:

答案 0 :(得分:1)

Spring AOP只能为Spring组件创建代理,并向其添加方面拦截器(建议)。您的类Test不是@Component,我看不到有任何配置可以从中创建Spring bean。

答案 1 :(得分:-1)

尝试在@Around批注中添加完整的软件包:

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