一、aop基础知识
Spring AOP 详细深入讲解+代码示例
二、spring/spring boot/spring cloud中出现的注解/类与概念的对应
@Aspect:
标注当前MyAspect是一个切面类,–》对应切面的概念,在切面类中有用@Before等注解修饰的方法作为advice,也有用@pointPointcut修饰的方法去定义切点,还会在方法中使用的ProceedingJoinPoint类 和 JoinPoint类 对应切面的连接点
SpringAOP中的JointPoint和ProceedingJoinPoint使用详解(附带详细示例)
三、切点表达式
//定义切点表达式
@Pointcut("execution(* com.itheima.anno.*.*(..))")
public void pointcut(){}
第15章-Spring AOP切点表达式(Pointcut)详解
四、不添加@EnableAspectJAutoProxy–来自GPT
在Spring Framework的应用中,@EnableAspectJAutoProxy注解启用了对AspectJ注解切面(如使用@Aspect注解的类)的支持,进而允许Spring通过代理为Beans提供面向切面的编程(AOP)功能。对于大部分基于Spring Boot的应用,实际上并不需要显式地添加@EnableAspectJAutoProxy注解。这是因为Spring Boot自动配置会默认开启这项功能。让我们来详细了解一下Spring Boot自动配置在这方面是如何工作的。
Spring Boot的自动配置行为
对于使用spring-boot-starter-aop依赖的Spring Boot应用,AOP支持是通过自动配置开启的,这一点体现在AopAutoConfiguration中。这样,就不需要开发者显式地在自己的配置类中添加@EnableAspectJAutoProxy。
具体来说,spring-boot-starter-aop提供的AopAutoConfiguration会自动注册一个AnnotationAwareAspectJAutoProxyCreator的Bean到Spring容器中。这个Bean是启用@AspectJ支持的关键,意味着Spring Boot会自动处理使用@Aspect注解的类,并按照这些类中定义的切面逻辑对目标方法进行增强(例如,应用前置、后置或环绕通知等)。
如果不添加@EnableAspectJAutoProxy
在Spring Boot应用中,如果你没有显式添加@EnableAspectJAutoProxy:
没有影响:在大多数情况下,不显式添加@EnableAspectJAutoProxy对应用没有影响。这是因为Spring Boot的AopAutoConfiguration已经为你启用了AspectJ的自动代理支持。你的AOP逻辑(如@Before、@AfterReturning、@Around、@AfterThrowing注解标注的方法)应该会按预期工作。
特定情景下的差异:显式添加@EnableAspectJAutoProxy仍然可以在特定情境下提供灵活性。例如,如果你需要使用AspectJ编译时织入(而不是在运行时通过Spring AOP的代理机制),或者需要精细控制AOP的某些行为,如proxyTargetClass属性。@EnableAspectJAutoProxy(proxyTargetClass = true)可以强制使用CGLIB代理而不是JDK动态代理(无论接口的存在与否),这在处理没有接口的类时可能很有用。
小结
总结来说,在Spring Boot应用中,通过spring-boot-starter-aop依赖引入AOP支持通常是足够的,无需显式添加@EnableAspectJAutoProxy。只在有特定需求时,才可能需要显式使用此注解来控制AOP的细节行为。这体现了Spring Boot“约定大于配置”的设计理念,尽最大可能简化Spring应用的开发。