小編給大家分享一下Spring AOP中如何實(shí)現(xiàn)自動代理,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
成都創(chuàng)新互聯(lián)公司是專業(yè)的常寧網(wǎng)站建設(shè)公司,常寧接單;提供成都網(wǎng)站建設(shè)、成都做網(wǎng)站,網(wǎng)頁設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行常寧網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來合作!
這里的自動代理,我講的是自動代理bean對象,其實(shí)就是在xml中讓我們不用配置代理工廠,也就是不用配置class為org.springframework.aop.framework.ProxyFactoryBean的bean。
總結(jié)了一下自己目前所學(xué)的知識。
發(fā)現(xiàn)有三種方式實(shí)現(xiàn)自動代理
用Spring一個(gè)自動代理類DefaultAdvisorAutoProxyCreator:
例如:
原來不用自動代理的配置文件如下:
.*run.*
advisor
現(xiàn)在改用自動代理,如下配置:
.*run.*
測試方法
@Test//自動代理 public void demo4(){ ApplicationContext ctx = new ClassPathXmlApplicationContext("cn/hncu/xmlImpl/4.xml"); //我們直接在這里獲取Person對象就可以了,因?yàn)樵谧铋_始xml文件newPerson對象后,Spring就已經(jīng)幫我們代理了! Person p =ctx.getBean(Person.class); p.run(); p.say(); }
相對于前面,也就是把代理工廠部分換成自動代理了。
演示結(jié)果:
自己寫一個(gè)自動代理底層實(shí)現(xiàn):
我們也可以寫一個(gè)類,來實(shí)現(xiàn)DefaultAdvisorAutoProxyCreator自動代理的功能!
首先,我們需要實(shí)現(xiàn)一個(gè)接口,也就是BeanPostProcessor接口。
BeanPostProcessor接口作用是:如果我們需要在Spring容器完成Bean的實(shí)例化、配置和其他的初始化前后添加一些自己的邏輯處理,我們就可以定義一個(gè)或者多個(gè)BeanPostProcessor接口的實(shí)現(xiàn),然后注冊到容器中。
而我們想要在原型對象bean被創(chuàng)建之后就代理了,就必須在原來的容器中拿到原來的原型對象,需要拿到原來spring容器中的切面對象,這個(gè)時(shí)候,我們就需要原來的容器,這個(gè)時(shí)候就需要另一個(gè)接口,也就是ApplicationContextAware接口!
通過這2個(gè)接口,我們就可以實(shí)現(xiàn)自動代理了。
package cn.hncu.xmlImpl; import org.springframework.aop.Advisor; import org.springframework.aop.framework.ProxyFactoryBean; import org.springframework.beans.BeansException; import org.springframework.beans.factory.config.BeanPostProcessor; import org.springframework.context.ApplicationContext; import org.springframework.context.ApplicationContextAware; public class MyAutoProxy implements BeanPostProcessor,ApplicationContextAware{ private ApplicationContext applicationContext=null; //bean創(chuàng)建之前調(diào)用 @Override public Object postProcessBeforeInitialization(Object bean, String beanName) throws BeansException { return bean;//在這里,我們直接放行 } //bean創(chuàng)建之后調(diào)用 @Override public Object postProcessAfterInitialization(Object bean, String beanName) throws BeansException { ProxyFactoryBean factory = new ProxyFactoryBean(); //把原型對象放入代理工廠 factory.setTarget(bean); //在這里 Advisor adv = applicationContext.getBean(Advisor.class); factory.addAdvisor(adv); //返回被代理后的對象 return factory.getObject(); } //拿到原來的spring中的容器 @Override public void setApplicationContext(ApplicationContext applicationContext) throws BeansException { this.applicationContext=applicationContext; } }
5.xml
.*run.*
測試方法:
@Test//自己實(shí)現(xiàn)的自動代理 public void demo5(){ ApplicationContext ctx = new ClassPathXmlApplicationContext("cn/hncu/xmlImpl/5.xml"); Person p =ctx.getBean(Person.class); p.run(); p.say(); }
測試結(jié)果就不上圖了,和前面是一樣的。
其實(shí)很多時(shí)候,我們?nèi)绻约喝ゾ氁幌碌讓樱瑢ι蠈拥目蚣芨美斫狻?/p>
還有一種方法。
使用aop標(biāo)簽配自動代理
需要在beans加一個(gè)命名空間
xmlns:aop=https://www.springframework.org/schema/aop
還需要配xsi:schemaLocation,為aop加一個(gè)網(wǎng)絡(luò)地址。
https://www.springframework.org/schema/aop https://www.springframework.org/schema/aop/spring-aop-4.3.xsd
我們需要一個(gè)aspectjweaver-jar包:
xml配置文件:
.*run.*
測試方法:
@Test//自動代理 public void demo6(){ ApplicationContext ctx = new ClassPathXmlApplicationContext("cn/hncu/xmlImpl/6.xml"); Person p =ctx.getBean(Person.class); p.run(); p.say(); }
測試結(jié)果:
以上是“Spring AOP中如何實(shí)現(xiàn)自動代理”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!