spring 直接使用ProxyFactoryBean 实现AOP 流程小结

ProxyFactoryBean 是最原始的实现Spring AOP配置的方式

实例:

<bean id="testDaoService" class="com.daodao.mybatis.testDaoService"/>
    <bean id="testAOPAdvice" class="com.daodao.mybatis.testAOPAdvice"/>
    <bean id="regexpAdvisor" class="org.springframework.aop.support.RegexpMethodPointcutAdvisor"
    p:advice-ref="testAOPAdvice">
	    <property name="patterns">
	    	<list>
	    		<value>com\.daodao\.mybatis\..*</value>
	    	</list>
	    </property>
    </bean>
    <bean id="aoptest1" class="org.springframework.aop.framework.ProxyFactoryBean"
    p:interceptorNames="regexpAdvisor"
    p:target-ref="testDaoService"
    p:proxyTargetClass="true"/>

实例化过程主要类:

1.ProxyFactoryBean

2.RegexpMethodPointcutAdvisor

3.DefaultAopProxyFactory

4.JdkDynamicAopProxy+ObjenesisCglibAopProxy



1.ProxyFactoryBean 继承FactoryBean接口,getObject()方法在实例化bean的时候被调用,返回值为代理对象

a. getObject()方法首先initializeAdvisorChain(); 将RegexpMethodPointcutAdvisor添加至ProxyFactoryBean的advisors

b. 非prototype时调用getSingletonInstance();将自己作为参数传给DefaultAopProxyFactory.createAopProxy(AdvisedSupport config)去创建代理对象。


2.DefaultAopProxyFactory 根据传输的AdvisedSupport的一些条件判定采用ObjenesisCglibAopProxy(AdvisedSupport config)还是JdkDynamicAopProxy(AdvisedSupport config)


3.JdkDynamicAopProxy 继承自 AopProxy接口的getProxy()方法被调用,Proxy.newProxyInstance(classLoader, proxiedInterfaces, this).其中this就是当前的JdkDynamicAopProxy(继承自InvocationHandler.).需要注意的是,JdkDynamicAopProxy持有了ProxyFactoryBean对象,间接的拥有了advisors,target.


4.ObjenesisCglibAopProxy 与3类似,实现是基于cglib



运行过程主要接口:

1.MethodInterceptor(实现类com.daodao.mybatis.testAOPAdvice)

2.MethodInvocation(实现类ReflectiveMethodInvocation)


1. JdkDynamicAopProxy 的invoke(Object proxy, Method method, Object[] args)会调用ReflectiveMethodInvocation.proceed();来处理整个流程

a.ReflectiveMethodInvocation 最终目的是将增强逻辑依次插入到现有方法实现的前后。其过程是先调用所有的MethodInterceptor的invoke(MethodInvocation invocation),该方法在实现中又会调用invocation.proceed();,直到所有的advice跑完,将会调用target的原有方法。是个递归调用。



总结:

仅对JDK动态代理来说,就是将所有的MethodInterceptor实现类和target被代理的类交给InvocationHandler,在InvocationHandler的invoke(Object proxy, Method method, Object[] args)调用中嵌套调用最终跑完所有的MethodInterceptor的invoke(MethodInvocation invocation)以及target的原本方法。


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring AOP动态代理是利用JDK的反射机制,在程序执行的时候动态创建代理类对象,并动态指定要代理的对象。它的作用是在不改变已有代码的基础上,通过代理来横向拓展增强其他的功能,减少重复的代码,专注业务逻辑代码,解耦业务代码与非业务代码的关系。\[1\] 在Spring AOP中,实现动态代理的方式有两种:静态代理和基于配置的动态代理。静态代理是通过手动编写代理类来实现,而基于配置的动态代理是通过在配置文件中进行配置来建立代理对象与目标对象之间的联系。\[2\] 在配置文件中,可以使用ProxyFactoryBean来创建代理对象,并指定要代理的目标对象、拦截器和代理接口。通过这种方式,可以实现对目标对象的代理,并在代理对象中添加额外的功能。\[2\] 然而,在配置过程中可能会遇到一些问题,比如依赖注入失败的异常。这可能是因为没有找到符合要求的bean,或者注入的依赖项没有正确配置。需要检查配置文件和注解的使用,确保所有的依赖项都正确配置和注入。\[3\] #### 引用[.reference_title] - *1* [SpringAOP之动态代理](https://blog.csdn.net/a55566999/article/details/125428712)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v4^insert_chatgpt"}} ] [.reference_item] - *2* *3* [Spring AOP之动态代理方式](https://blog.csdn.net/m0_53536589/article/details/123151359)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v4^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值