SpringBoot下的代理注解

@EnableAspectJAutoProxy

@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Import(AspectJAutoProxyRegistrar.class)
public @interface EnableAspectJAutoProxy {
	
    // 是否代理目标对象,ture:使用CGLIB代理 fasle:使用JDK代理
	boolean proxyTargetClass() default false;
	
    // 是否暴露代理对象
	boolean exposeProxy() default false;

}

@EnableAspectJAutoProxy 是一个Spring框架的注解,用于启用基于AspectJ的代理支持。它允许您使用面向切面编程 (AOP) 来实现横切关注点,例如日志记录、性能监控、事务管理等。

具体来说,@EnableAspectJAutoProxy 做了以下几件事情:

1、启用代理机制:它启用了Spring容器的代理功能,允许Spring创建代理对象,以拦截和处理方法调用,正常来说是不需要主动去加该注解,因为由于SpringBoot的自动配置会将代理机制自动开启,具体实现可参考本文最后推荐博文。

2、使用AspectJ注解:它启用了AspectJ注解,使您可以在Spring中使用 @Aspect@Before@After@Around 等注解来定义切面。

3、配置代理模式:它允许您选择代理的模式,通常是 proxyTargetClassexposeProxy 选项。proxyTargetClass 默认为 false,表示使用标准的JDK动态代理,如果将其设置为 true,则使用CGLIB代理。exposeProxy 默认为 false,表示不将当前代理对象暴露给切面,如果将其设置为 true,可以通过 AopContext.currentProxy() 获取当前代理对象。

以下是一个示例:

import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.EnableAspectJAutoProxy;

@Configuration
@EnableAspectJAutoProxy(proxyTargetClass = true, exposeProxy = true)
public class AppConfig {
    // Other bean configurations can go here
}

典型应用

1、解决由于代理实现的机制的失效问题:

        比如@Transactional事务、@Async异步,Service内部方法自调用导致的失效

// 配置暴露代理类,通过获取代理类调取方法
((TUserService) AopContext.currentProxy()).updateRealNameById(id, realName);

        

参考文章:【精选】Spring源码深度解析:十四、@Aspect方式的AOP上篇 - @EnableAspectJAutoProxy_enableaspectjautoproxy 是哪个包_代码的知行者的博客-CSDN博客

你可能感兴趣的:(spring,boot,java,spring)