当前位置:首页 > CN2资讯 > 正文内容

spring自动代理例子spring动态代理

2天前CN2资讯

http://www.blogjava.net/cmzy/archive/2008/08/17/222624.html


我们一直使用ProxyFactoryBean来显式的创建AOP代理。但是在很多场合,这种方式将会使编写配置文件的工作量大大增加;由于要从ProxyFactoryBean获得代理对象,也会使应用和Spring之间的耦合度增加。下面介绍使用Spring提供的自动代理机制来解决这类问题。

1、使用BeanNameAutoProxyCreator

      Spring提供的BeanNameAutoProxyCreator类允许我们通过Bean的name属性来指定代理的Bean。它暴露了java.lang.String[]类型的beanNames和 interceptorNames属性。beanNames可以指定被代理的Bean名字列表,支持“*”通配符,例如“*DAO”表示所有名字以“DAO”结尾的Bean。interceptorNames指定通知(Advice)列表,或者通知者(Advisor)列表。

       下面通过一个例程来演示如何使用BeanNameAutoProxyCreator。在例子中,有两个Bean:TestBeanA和BeanB,并在TestMain类中的main方法中调用其MyMethod()方法。自动代理将会在方法调用前自动的执行配置的前置通知,输出提示信息。

新建一个名字为AOP_Test4.10的工程,添加Spring的IoC和AOP库后,新建一aop.test包,再分别创建两个类TestBeanA和BeanB,添加MyMethod()方法,代码如下:

代码查看源代码copy to clipboard打印
  • /**

  • *

  • */

  • package aop.test;  

  • /**

  • * @author zhangyong

  • *

  • */

  • publicclass TestBeanA {  

  • publicvoid MyMethod() {  

  •          System.out.println(this.getClass().getName()  

  •                + ".MyMethod() is run!");  

  •     }  

  • }  

  • /** * */ package aop.test; /** * @author zhangyong * */ public class TestBeanA { public void MyMethod() { System.out.println(this.getClass().getName() + ".MyMethod() is run!"); } }

    代码查看源代码copy to clipboard打印
  • /**

  • *

  • */

  • package aop.test;    

  • /**

  • * @author zhangyong

  • *

  • */

  • publicclass BeanB {      

  • publicvoid MyMethod() {  

  •         System.out.println(this.getClass().getName()  

  •                 + ".MyMethod() is run!");  

  •    }  

  • }  

  • /** * */ package aop.test; /** * @author zhangyong * */ public class BeanB { public void MyMethod() { System.out.println(this.getClass().getName() + ".MyMethod() is run!"); } }

      再创建前置通知类BeforeAdvice:

    代码查看源代码copy to clipboard打印
  • /**

  • *

  • */

  • package aop.test;    

  • import java.lang.reflect.Method;  

  • import org.springframework.aop.MethodBeforeAdvice;    

  • /**

  • * @author zhangyong

  • *

  • */

  • publicclass BeforeAdvice implements MethodBeforeAdvice {    

  • publicvoid before(Method method, Object[] args, Object target)  

  • throws Throwable {  

  •         System.out.println(method.getName() + "(),将要运行!");  

  •     }  

  • }  

  • /** * */ package aop.test; import java.lang.reflect.Method; import org.springframework.aop.MethodBeforeAdvice; /** * @author zhangyong * */ public class BeforeAdvice implements MethodBeforeAdvice { public void before(Method method, Object[] args, Object target) throws Throwable { System.out.println(method.getName() + "(),将要运行!"); } }

      最后创建含有main方法的测试类TestMain:

    代码查看源代码copy to clipboard打印
  • /**

  • *

  • */

  • package aop.test;  


  • import org.springframework.context.ApplicationContext;  

  • import org.springframework.context.support.ClassPathXmlApplicationContext;    

  • /**

  • * @author zhangyong

  • *

  • */

  • publicclass TestMain {  

  • publicstaticvoid main(String[] args) {  

  •         ApplicationContext ac = new ClassPathXmlApplicationContext(  

  • "applicationContext.xml");          

  •         TestBeanA beanA = (TestBeanA)ac.getBean("TestBeanA");  

  •         beanA.MyMethod();  

  •         BeanB beanB = (BeanB)ac.getBean("BeanB");  

  •         beanB.MyMethod();          

  •     }  

  • }  

  • /** * */ package aop.test; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; /** * @author zhangyong * */ public class TestMain { public static void main(String[] args) { ApplicationContext ac = new ClassPathXmlApplicationContext( "applicationContext.xml"); TestBeanA beanA = (TestBeanA)ac.getBean("TestBeanA"); beanA.MyMethod(); BeanB beanB = (BeanB)ac.getBean("BeanB"); beanB.MyMethod(); } }

      在配置文件中配置Bean和自动代理Bean,完成后代码如下:

    代码查看源代码copy to clipboard打印
  • <?xmlversion="1.0"encoding="UTF-8"?>

  • <beans …………>

  • <beanid="TestBeanA"class="aop.test.TestBeanA"/>

  • <beanid="BeanB"class="aop.test.BeanB"/>

  • <beanid="BeforeAdvice"class="aop.test.BeforeAdvice"></bean>


  • <beanclass="org.springframework.aop.framework.autoproxy.  

  •                       BeanNameAutoProxyCreator">

  • <propertyname="beanNames">

  • <list>

  • <value>Test*</value>

  • </list>

  • </property>

  • <propertyname="interceptorNames">

  • <list>

  • <value>BeforeAdvice</value>

  • </list>

  • </property>

  • </bean>

  • </beans>

  • <?xml version="1.0" encoding="UTF-8"?> <beans …………> <bean id="TestBeanA" /> <bean id="BeanB" /> <bean id="BeforeAdvice" ></bean> <bean > <property name="beanNames"> <list> <value>Test*</value> </list> </property> <property name="interceptorNames"> <list> <value>BeforeAdvice</value> </list> </property> </bean> </beans>

      运行主类,输出结果如下:

      可以看到,在主类TestMain中,我们是直接从Spring IoC容器中获取收管Bean而不是像以前那样从ProxyFactoryBean中获取代理,但是我们的前置通知BeforeAdvice仍然在TestBeanA对象的MyMethod()方法执行前被触发,这说明我们的自动代理正在工作。


    2、使用DefaultAdvisorAutoProxyCreator

      DefaultAdvisorAutoProxyCreator允许我们只需定义相应的Advisor通知者,就可以完成自动代理。配置好DefaultAdvisorAutoProxyCreator受管Bean后,它会自动查找配置文件中定义的Advisor,并将它们作用于所有的Bean。

    修改例程4.10的配置文件,使用DefaultAdvisorAutoProxyCreator来完成自动代理。完成后配置文件代码如下(本例完整工程代码见例程4.11):

    代码查看源代码copy to clipboard打印
  • <?xmlversion="1.0"encoding="UTF-8"?>

  • <beans ……>

  • <beanid="TestBeanA"class="aop.test.TestBeanA"/>

  • <beanid="BeanB"class="aop.test.BeanB"/>

  • <beanid="BeforeAdvice"class="aop.test.BeforeAdvice"/>

  • <beanclass="org.springframework.aop.framework.autoproxy.  

  •                   DefaultAdvisorAutoProxyCreator" />


  • <beanclass="org.springframework.aop.support.NameMatchMethod  

  •                                          PointcutAdvisor">

  • <propertyname="advice"ref="BeforeAdvice"/>

  • <propertyname="mappedNames">

  • <list>

  • <value>*Method*</value>

  • </list>

  • </property>

  • </bean>

  • </beans>

  • <?xml version="1.0" encoding="UTF-8"?> <beans ……> <bean id="TestBeanA" /> <bean id="BeanB" /> <bean id="BeforeAdvice" /> <bean /> <bean > <property name="advice" ref="BeforeAdvice" /> <property name="mappedNames"> <list> <value>*Method*</value> </list> </property> </bean> </beans>

      运行主类输出结果如下:


      你可能想看:

      扫描二维码推送至手机访问。

      版权声明:本文由皇冠云发布,如需转载请注明出处。

      本文链接:https://www.idchg.com/info/32186.html

      分享给朋友:

      “spring自动代理例子spring动态代理” 的相关文章

      中国电信CN2网络接入不了的原因解析及解决方案

      在数字化时代,网络连接已成为我们生活中不可或缺的一部分。对于企业用户来说,中国电信CN2网络作为一张高可靠、低时延的网络,为广大用户提供了优质的网络服务。一些用户近期反映中国电信CN2网络接入不了的问题,这不仅影响了用户体验,也可能对企业正常运营造成干扰。中国电信CN2网络接入不了的原因到底是什么呢...

      Siteground怎么样?深入分析其安全性、正常运行时间与客户支持

      Siteground的安全性实践 谈到Siteground的安全性实践,我总是很欣赏他们的努力。作为一个成立于2004年的托管服务商,Siteground在安全方面采取了多重措施。我注意到,首先,他们为所有用户提供免费的Let’s Encrypt SSL证书。SSL证书能够加密网站与访客之间的数据,...

      KVM是什么?深入了解KVM的定义、工作原理及应用场景

      KVM的定义与概念 谈到KVM时,首先想到的就是“键盘、显示器和鼠标”的组合,它让我们可以用一组设备控制多台计算机。这种技术非常适合在数据中心或需要远程管理的环境中使用。我对这个系统产生了兴趣,因为它显著提高了管理效率,节省了空间,还所有的操作都变得更简便。想象一下,如果有多台服务器,你需要同时监控...

      选择台湾VPS的优势与实用技巧分析

      在当今互联网迅速发展的时代,虚拟专用服务器(VPS)成为了众多企业和个人不二的选择。台湾VPS作为一个相对新兴的产品,凭借自己独特的地理位置和优异的技术性能,逐渐在市场上占据了一席之地。身为个人或企业,在选择服务器时,了解台湾VPS的基本概念及其优势无疑是一个明智的开始。 什么是VPS? VPS,即...

      IPv6 测速方法与工具:提升网络体验的技巧

      IPv6 测速的基本概念 IPv6,作为互联网协议的最新版本,让我们在网络世界中畅游无阻。它的推出旨在解决IPv4所面临的地址枯竭问题,推进更加广泛的设备连接。简单来说,IPv6提供了更大的地址空间,能够支持越来越多的设备上线。因为万物互联的时代已经来临,我们的手机、电脑、家居设备甚至汽车都需要连接...

      AMD Ryzen VPS 性能测评:RackNerd 的优越体验与机房对比

      当我开始使用RackNerd的VPS服务时,我被它的低价和强大性能所吸引。作为一个刚入驻云计算的用户,我知道许多商家提供VPS,但RackNerd以十美元每年的超低价格引起了我的注意。而真正让我印象深刻的是它的稳定性与出色的售后服务。我曾多次遇到技术问题,售后支持总能在第一时间给我回应,这让我感受到...