aop:aspectj-autoproxy的内部机制

本文介绍了Spring中如何使用@EnableAspectJAutoProxy注解或<aop:aspectj-autoproxy/>元素来配置AspectJ切面的自动代理。通过具体代码示例展示了如何定义切面类和服务类,并解释了proxyTargetClass属性的作用。

要说Spring xml配置中的<aop:aspectj-autoproxy />,先从@EnableAspectJAutoProxy注解说起,

Spring的配置除了使用xml之外,还可以使用Java+ 注解的方式,例如下面的AppConfig类:

// 配置文件类

 @Configuration
 @EnableAspectJAutoProxy
 public class AppConfig {
     @Bean
     public FooService fooService() {
         return new FooService();
     }

     @Bean // the Aspect itself must also be a Bean
     public MyAspect myAspect() {
         return new MyAspect();
     }
 }

----------------------------------------

// Service类

 public class FooService {
     // various methods
 }

----------------------------------------

// 切面类

 @Aspect
 public class MyAspect {
     @Before("execution(* FooService+.*(..))")
     public void advice() {
         // advise FooService methods as appropriate
     }
 }

其中@EnableAspectJAutoProxy注解会确保MyAspect切面被合理地处理并且FooService类会被自动创建代理,Spring 在内部会采用AnnotationAwareAspectJAutoProxyCreator进行自动代理的创建工作。

用户可以自己控制代理的类型,通过proxyTargetClass属性,默认false,采用JDK动态代理织入增强;如果设为true,则采用CGLIB动态代理织入增强。不过即使proxyTargetClass设置为false,如果目标类没有声明接口,则Spring将自动使用CGLib动态代理。

注意,@Aspect切面类也可以同时加上@Component注解,通过包扫描来实现bean的自动注册。

 

如果使用xml配置,则使用<aop:aspectj-autoproxy/>,效果等同于@EnableAspectJAutoProxy

 

参考资料:

http://docs.spring.io/spring/docs/current/javadoc-api/org/springframework/context/annotation/EnableAspectJAutoProxy.html

在Spring AOP中,`<aop:aspectj-autoproxy/>` 是一个XML配置元素,用于启用基于AspectJ的自动代理功能。与该配置相对应的注解形式是 `@EnableAspectJAutoProxy`。通过在配置类上添加此注解,可以实现与 `<aop:aspectj-autoproxy/>` 相同的功能[^2]。 `@EnableAspectJAutoProxy` 注解支持两个重要的属性: 1. `proxyTargetClass`:该属性用于指定是否使用CGLIB代理,默认值为 `false`。当设置为 `true` 时,Spring 会为目标类生成子类代理,而不是基于接口的JDK动态代理[^2]。 ```java @Configuration @EnableAspectJAutoProxy(proxyTargetClass = true) public class AppConfig { // 配置内容 } ``` 2. `exposeProxy`:该属性用于指定是否将代理对象暴露在 `AopContext` 中,默认值为 `false`。若设置为 `true`,可以通过 `AopContext.currentProxy()` 获取当前代理对象[^3]。 ```java @Configuration @EnableAspectJAutoProxy(exposeProxy = true) public class AppConfig { // 配置内容 } ``` 这些属性提供了对代理行为的更细粒度控制,适用于不同的使用场景。 ### 三级标题:注解与XML配置的对应关系 - `<aop:aspectj-autoproxy proxy-target-class="true"/>` 对应 `@EnableAspectJAutoProxy(proxyTargetClass = true)`[^2]。 - `<aop:aspectj-autoproxy expose-proxy="true"/>` 对应 `@EnableAspectJAutoProxy(exposeProxy = true)`[^3]。 通过使用 `@EnableAspectJAutoProxy`,可以完全替代 `<aop:aspectj-autoproxy/>` 的XML配置,从而实现基于注解的AOP配置方式。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值