Spring Aop基本流程原理示例詳解
一、代理對(duì)象的創(chuàng)建過程:
AbstractAutowireCapableBeanFactory#initializeBean
protectedObjectinitializeBean(StringbeanName,Objectbean,@NullableRootBeanDefinitionmbd){ if(System.getSecurityManager()!=null){ AccessController.doPrivileged((PrivilegedAction<Object>)()->{ invokeAwareMethods(beanName,bean); return null; },getAccessControlContext()); } else{ invokeAwareMethods(beanName,bean); } ObjectwrappedBean=bean; if(mbd==null||!mbd.isSynthetic()){ // 執(zhí)⾏所有的BeanPostProcessor#postProcessBeforeInitialization 初始化之前 的處理器⽅法 wrappedBean=applyBeanPostProcessorsBeforeInitialization(wrappedBean,beanName); } try{ // 這⾥就開始執(zhí)⾏afterPropertiesSet(實(shí)現(xiàn)了InitializingBean接⼝)⽅法和 initMethod invokeInitMethods(beanName,wrappedBean,mbd); } catch(Throwableex){ thrownewBeanCreationException((mbd!=null? mbd.getResourceDescription():null),beanName,"Invocationofinitmethodfailed",ex); } if(mbd==null||!mbd.isSynthetic()){ // 整個(gè)Bean初始化完成,執(zhí)⾏后置處理器⽅法 wrappedBean=applyBeanPostProcessorsAfterInitialization(wrappedBean,beanName); } return wrappedBean; }
可以看到有初始化前執(zhí)行的方法、初始化時(shí)執(zhí)行的方法、初始化之后執(zhí)行的方法,我們從初始化之后執(zhí)行的方法入手。
二、applyBeanPostProcessorsAfterInitialization
applyBeanPostProcessorsAfterInitialization()方法的流程如下:
AbstractAutowireCapableBeanFactory#applyBeanPostProcessorsAfterInitialization ->AbstractAutoProxyCreator#postProcessAfterInitialization
applyBeanPostProcessorsAfterInitialization中會(huì)檢查下該類是否已經(jīng)暴露過了(可能已經(jīng)創(chuàng)建了,⽐如A依賴B時(shí),創(chuàng)建A時(shí)候,就會(huì)先去創(chuàng)建B。當(dāng)真正需要?jiǎng)?chuàng)建B時(shí),就沒必要再代理⼀次已經(jīng)代理過的對(duì)象),避免重復(fù)創(chuàng)建。
->AbstractAutoProxyCreator#wrapIfNecessary
得到所有候選Advisor,對(duì)Advisors和bean的⽅法雙層遍歷匹配,最終得到⼀個(gè)List<Advisor>,即specificInterceptors
->AbstractAutoProxyCreator#createProxy
(1)創(chuàng)建代理的⼯作交給ProxyFactory
(2)把指定和通⽤攔截對(duì)象合并, 并都適配成Advisor
(3)上⾯準(zhǔn)備做完就開始創(chuàng)建代理
->proxyFactory.getProxy()
⽤ProxyFactory創(chuàng)建AopProxy, 然后⽤AopProxy創(chuàng)建Proxy, 所以這⾥重要的是看獲取的AopProxy對(duì)象是什么,然后進(jìn)去看怎么創(chuàng)建動(dòng)態(tài)代理, 提供了兩種:jdk proxy, cglib
總結(jié):簡要流程
總結(jié)
到此這篇關(guān)于Spring Aop基本流程原理的文章就介紹到這了,更多相關(guān)Spring Aop流程原理內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用Prometheus+Grafana的方法監(jiān)控Springboot應(yīng)用教程詳解
這篇文章主要介紹了用Prometheus+Grafana的方法監(jiān)控Springboot應(yīng)用,本文通過實(shí)例代碼詳解給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-03-03Netty源碼分析NioEventLoop執(zhí)行select操作入口
這篇文章主要介紹了Netty源碼分析NioEventLoop執(zhí)行select操作入口,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-03-03java中排序報(bào):Comparison method violates its general contract異常的解
這篇文章主要給大家介紹了關(guān)于java中排序報(bào):Comparison method violates its general contract異常的解決方法,文中介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起看看吧。2017-06-06Java實(shí)現(xiàn)赫夫曼樹(哈夫曼樹)的創(chuàng)建
給定N個(gè)權(quán)值作為N個(gè)葉子結(jié)點(diǎn),構(gòu)造一棵二叉樹,若該樹的帶權(quán)路徑長度(WPL)達(dá)到最小,稱這樣的二叉樹為最優(yōu)二叉樹,也稱為哈夫曼樹(Huffman Tree)。這篇文章主要就是為大家介紹如何通過Java實(shí)現(xiàn)赫夫曼樹,需要的朋友可以參考一下2021-12-12Java 動(dòng)態(tài)生成類和實(shí)例, 并注入方法操作示例
這篇文章主要介紹了Java 動(dòng)態(tài)生成類和實(shí)例, 并注入方法操作,結(jié)合實(shí)例形式分析了Java 動(dòng)態(tài)生成類和實(shí)例以及動(dòng)態(tài)注入相關(guān)操作技巧,需要的朋友可以參考下2020-02-02小米Java程序員第二輪面試10個(gè)問題 你是否會(huì)被刷掉?
小米Java程序員第二輪面試10個(gè)問題,你是否會(huì)被刷掉?掌握好基礎(chǔ)知識(shí),祝大家面試順利2017-11-11