溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Springboot源碼中的AbstractAdvisorAutoProxyCreator分析

發(fā)布時(shí)間:2021-11-17 09:18:31 來(lái)源:億速云 閱讀:278 作者:iii 欄目:大數(shù)據(jù)

這篇文章主要講解了“Springboot源碼中的AbstractAdvisorAutoProxyCreator分析”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“Springboot源碼中的AbstractAdvisorAutoProxyCreator分析”吧!

摘要:

Spring的代理在上層中主要分為ProxyCreatorSupportProxyProcessorSupport,前者是基于代理工廠,后者是基于后置處理器,也可以認(rèn)為后置就是自動(dòng)代理器。當(dāng)spring容器中需要進(jìn)行aop進(jìn)行織入的bean較多時(shí),簡(jiǎn)單采用ProxyFacotryBean無(wú)疑會(huì)增加很多工作量(因?yàn)槊總€(gè)Bean!都得手動(dòng)寫一個(gè))。所以自動(dòng)代理就發(fā)揮它的作用了。

Springboot源碼中的AbstractAdvisorAutoProxyCreator分析

Spring中自動(dòng)創(chuàng)建代理器分類

在內(nèi)部,Spring使用BeanPostProcessor讓自動(dòng)生成代理?;贐eanPostProcessor的自動(dòng)代理創(chuàng)建器的實(shí)現(xiàn)類,將根據(jù)一些規(guī)則在容器實(shí)例化Bean時(shí)為匹配的Bean生成代理實(shí)例。代理創(chuàng)建器可以分為三類:

  • 基于Bean配置名規(guī)則的自動(dòng)代理生成器:允許為一組特定配置名的Bean自動(dòng)創(chuàng)建代理實(shí)例的代理創(chuàng)建器,實(shí)現(xiàn)類為BeanNameAutoProxyCreator

  • 基于Advisor匹配機(jī)制的自動(dòng)代理創(chuàng)建器它會(huì)對(duì)容器中的所有Advisor進(jìn)行掃描,自動(dòng)將這些切面應(yīng)用到匹配的Bean中,實(shí)現(xiàn)類是DefaultAdvisorAutoProxyCreator(它也支持前綴匹配)

  • 基于Bean中AspectJ注解的自動(dòng)代理生成器:為包含AspectJ注解的切入的Bean自動(dòng)創(chuàng)建代理實(shí)例,實(shí)現(xiàn)類是AnnotationAwareAspectJAutoProxyCreator,它是我們的@EnableAspectJAutoProxy導(dǎo)入的,這也是我們當(dāng)下使用最為廣泛的方式~

BeanNameAutoProxyCreator
    package com.github.dqqzj.springboot.aop;
    
    import org.springframework.aop.framework.autoproxy.BeanNameAutoProxyCreator;
    import org.springframework.stereotype.Component;
    
    import javax.annotation.PostConstruct;
    
    /**
     * @author qinzhongjian
     * @date created in 2019-08-25 09:43
     * @description: TODO
     * @since JDK 1.8.0_212-b10
     */
    @Component
    public class MyBeanNameAutoProxyCreator extends BeanNameAutoProxyCreator {
        @PostConstruct
        public void init() {
            super.setBeanNames("aopService", "abstractAutoProxyCreatorService");
            super.setInterceptorNames("myMethodBeforeAdvice");
        }
    
    }

Springboot源碼中的AbstractAdvisorAutoProxyCreator分析

如果你想用自己注冊(cè)的@Bean代替@EnableAspectJAutoProxy默認(rèn)給你注冊(cè)的自動(dòng)創(chuàng)建器AnnotationAwareAspectJAutoProxyCreator,那么你可以注冊(cè)一個(gè)Bean名稱如下的Bean即可:

    // 手動(dòng)注冊(cè)一個(gè)自動(dòng)代理創(chuàng)建器,且名字務(wù)必叫AopConfigUtils.AUTO_PROXY_CREATOR_BEAN_NAME
    @Bean(AopConfigUtils.AUTO_PROXY_CREATOR_BEAN_NAME) 
    public BeanNameAutoProxyCreator beanNameAutoProxyCreator() {
    	...
    }
AbstractAutoProxyCreator
    public abstract class AbstractAutoProxyCreator extends ProxyProcessorSupport
    		implements SmartInstantiationAwareBeanPostProcessor, BeanFactoryAware {
    		...
    }

AbstractAutoProxyCreator是對(duì)自動(dòng)代理創(chuàng)建器的一個(gè)抽象實(shí)現(xiàn)。最重要的是,它實(shí)現(xiàn)了SmartInstantiationAwareBeanPostProcessor接口,因此會(huì)介入到Spring IoC容器Bean實(shí)例化的過程,在AbstractAutowireCapableBeanFactory中有這樣一段代碼

    try {
    			// Give BeanPostProcessors a chance to return a proxy instead of the target bean instance.
    			Object bean = resolveBeforeInstantiation(beanName, mbdToUse);
    			if (bean != null) {
    				return bean;
    			}
    		}

但是一般都不會(huì)生效的,因?yàn)檫@個(gè)resolveBeforeInstantiation只是針對(duì)有自定義的targetsource,因?yàn)樽远x的targetsource不是spring的bean那么肯定不需要進(jìn)行后續(xù)的一系列的實(shí)例化 初始化。所以可以在resolveBeforeInstantiation直接進(jìn)行proxy。簡(jiǎn)單的說吧 ,這個(gè)代碼可以忽略不計(jì),開發(fā)者一般用不到。

如何讓resolveBeforeInstantiation直接返回bean?
    package com.github.dqqzj.springboot.aop;
    
    import org.springframework.beans.BeansException;
    import org.springframework.beans.factory.config.InstantiationAwareBeanPostProcessor;
    
    /**
     * @author qinzhongjian
     * @date created in 2019-08-25 11:35
     * @description: TODO
     * @since JDK 1.8.0_212-b10
     */
    public class AopServiceInstantiationAwareBeanPostProcessor implements InstantiationAwareBeanPostProcessor {
        @Override
        public Object postProcessBeforeInstantiation(Class<?> beanClass, String beanName) throws BeansException {
            if (beanClass.isInstance(AopService.class)) {
                return new AopService();
            }
            return null;
        }
        @Override
        public Object postProcessAfterInitialization(Object bean, String beanName) throws BeansException {
            return bean;
        }
    }

Springboot源碼中的AbstractAdvisorAutoProxyCreator分析

這個(gè)是spring第一次后置處理器的使用,如果這樣直接就返回了,就相當(dāng)于脫離了IOC的生命周期了一樣,依賴注入,屬性填充等這些都沒有進(jìn)行處理,所以使用的時(shí)候一定要注意,最好別使用這個(gè)功能。

感謝各位的閱讀,以上就是“Springboot源碼中的AbstractAdvisorAutoProxyCreator分析”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對(duì)Springboot源碼中的AbstractAdvisorAutoProxyCreator分析這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI