Spring Aop

三种方式:ProxyFactoryBean,BeanNameAutoProxyCreator,基于标签或注解形式
1、ProxyFactoryBean
只能代理一个类
targetBean  interceptorNames     proxyInterfaces
它是一个FactoryBean,通过getObject来获取目标对象生成代理对象所用的工具是AopProxy.getProxy。两种实现类:
JdkDynamicAopProxy     Cglib2AopProxy
前者是通过JDK的动态代理接口做的。
Proxy.newProxyInstance(loader, interfaces, InvocationHandler)
JdkDynamicAopProxy实现InvocationHandler
invoke(proxy, method, args) {
     new *MethodInvocation(proxy, target, method, interceptors).proceed()
}
 
Spring的拦截器需要实现aopalliance的接口,要么直接实现MethodInterceptor,要么实现MethodBeforeAdvice,AfterReturningAdvice,ThrowsAdvice。因为这三种会有对应的MethodBeforeAdviceAdapter,AfterReturningAdviceAdapter,ThrowsAdviceAdapter作为适配器,如果配上了,会分别用MethodBeforeAdviceInterceptor,AfterReturningAdviceInterceptor,ThrowsAdviceInterceptor包装advice对象成为MethodInterceptor类型。
 
aopalliance接口结构图
。。。。。。。
 
2、BeanNameAutoProxyCreator
能通过beanNames匹配来生成代理对象,是批量的
beanNames     interceptorNames
 
它是一个BeanPostProcessor,在每个Bean实例化完并且初始化完成之后,会触发这个后置处理器的postProcessAfterInitialization(bean, beanName),如果匹配上beanNames,就会返回一个代理。所用的还是AopProxy,即JdkDynamicAopProxy或Cglib2AopProxy
 
3、基于标签或注解的形式
标签:
<aop:config>                      表示提供对xml声明式Aop支持            后置处理器为AspectJAwareAdvisorAutoProxyCreator
<aop:aspectj-autoproxy>     表示提供对@Aspectj注解式Aop支持   后置处理器为AnnotationAwareAspectjAutoProxyCreator
<aop:aspectj-autoproxy proxy-target-class="false" >表示用JdkDynamicAopProxy来创建(如果没有接口,还是用Cglib)
 
<bean id="**MethodInterceptor">
<aop:config>
     <aop:pointcut id="p1" expression="execution( *com.xussen.Service.save*(..))">
     <aop:advisor pointcut-ref="p1" advice-ref="**MethodInterceptor">
</aop:config>
<aop:config>
     <aop:aspect id="" ref="aspect对象">
          <aop:pointcut id="" expression="">
          <aop:before method="" pointcut-ref="">
          <aop:after method="" pointcut-ref="">
     </aop:aspect>
</aop:config>
注解:
@Aspectj
class AspectAdvice {
     @Pointcut("execution( *com.xussen.*Server.save*(..) || 。。。)")
     anyMethod(){}
 
     @Before("anyMethod")
     doBefore(JointPoint){...}
 
     @AfterReturning(value="anyMethod", returning="result")
     doAfterReturning(JointPoint, String result){...}
}
 
###Spring AOP 的概念 AOP(Aspect-Oriented Programming)即面向切面编程,是一种编程范式,旨在通过分离横切关注点来提高模块化程度。在 Spring 框架中,AOP 被广泛用于实现诸如日志记录、事务管理、安全性等通用功能,这些功能通常与业务逻辑无关但又需要在多个地方重复使用。 Spring AOP 主要是基于 AspectJ 实现的,尽管 AspectJ 是一个独立的 AOP 框架,并不是 Spring 的组成部分,但它通常与 Spring 一起使用以提供更强大的 AOP 功能[^1]。Spring AOP 支持两种方式来定义切面:基于 XML 配置文件的方式和基于注解的方式。 ###Spring AOP 的原理 Spring AOP 使用运行时代理来实现 AOP 功能,这意味着它会在运行时动态生成代理对象。对于实现了接口的类,Spring AOP 默认使用 JDK 动态代理;而对于没有实现接口的类,则会使用 CGLIB 代理[^4]。这种方式允许在不修改原始代码的情况下向程序中添加新的行为。 织入(Weaving)是将增强(advice)应用到目标对象的过程,Spring AOP 在运行时进行织入操作[^3]。当创建了代理对象后,所有对目标对象方法的调用都会被拦截,并且可以插入额外的操作,比如在方法执行前后做一些处理。 ###Spring AOP 的使用教程 要开始使用 Spring AOP,首先需要确保项目中包含了必要的依赖。如果使用 Maven 构建工具,可以在 `pom.xml` 文件中加入如下依赖: ```xml <!-- 引入aop依赖 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-aop</artifactId> </dependency> ``` 一旦添加了依赖并刷新了 Maven 项目,就可以开始编写切面了。下面是一个简单的例子,展示如何使用注解来定义一个切面: ```java import org.aspectj.lang.annotation.Aspect; import org.aspectj.lang.annotation.Before; import org.springframework.stereotype.Component; @Aspect @Component public class LoggingAspect { @Before("execution(* com.example.service.*.*(..))") public void logBefore(JoinPoint joinPoint) { System.out.println("Method " + joinPoint.getSignature().getName() + " is called."); } } ``` 在这个示例中,`LoggingAspect` 类被标记为 `@Aspect` 和 `@Component` 注解,这样 Spring 就能识别这是一个切面组件。`@Before` 注解指定了在哪些方法上应用前置通知(before advice),这里的表达式表示匹配 `com.example.service` 包下所有的方法。 ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值