<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 241,  comments - 116,  trackbacks - 0
    我們一直使用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()方法,代碼如下:

    1. /** 
    2.  *  
    3.  */  
    4. package aop.test;  
    5. /** 
    6.  * @author zhangyong 
    7.  *  
    8.  */  
    9. public class TestBeanA {  
    10.      public void MyMethod() {  
    11.           System.out.println(this.getClass().getName()  
    12.                 + ".MyMethod() is run!");  
    13.      }  
    14. }  


    1. /** 
    2.  *  
    3.  */  
    4. package aop.test;    
    5. /** 
    6.  * @author zhangyong 
    7.  *  
    8.  */  
    9. public class BeanB {      
    10.     public void MyMethod() {  
    11.          System.out.println(this.getClass().getName()  
    12.                  + ".MyMethod() is run!");  
    13.     }  
    14. }  

      再創建前置通知類BeforeAdvice:

    1. /** 
    2.  *  
    3.  */  
    4. package aop.test;    
    5. import java.lang.reflect.Method;  
    6. import org.springframework.aop.MethodBeforeAdvice;    
    7. /** 
    8.  * @author zhangyong 
    9.  *  
    10.  */  
    11. public class BeforeAdvice implements MethodBeforeAdvice {    
    12.      public void before(Method method, Object[] args, Object target)  
    13.              throws Throwable {  
    14.          System.out.println(method.getName() + "(),將要運行!");  
    15.      }  
    16. }  

      最后創建含有main方法的測試類TestMain:

    1. /** 
    2.  *  
    3.  */  
    4. package aop.test;  
    5.    
    6. import org.springframework.context.ApplicationContext;  
    7. import org.springframework.context.support.ClassPathXmlApplicationContext;    
    8. /** 
    9.  * @author zhangyong 
    10.  *  
    11.  */  
    12. public class TestMain {   
    13.      public static void main(String[] args) {  
    14.          ApplicationContext ac = new ClassPathXmlApplicationContext(  
    15.                  "applicationContext.xml");          
    16.          TestBeanA beanA = (TestBeanA)ac.getBean("TestBeanA");  
    17.          beanA.MyMethod();  
    18.          BeanB beanB = (BeanB)ac.getBean("BeanB");  
    19.          beanB.MyMethod();          
    20.      }  
    21.  }  

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

    1. <?xml version="1.0" encoding="UTF-8"?>  
    2. <beans …………>   
    3.      <bean id="TestBeanA" class="aop.test.TestBeanA"/>  
    4.      <bean id="BeanB" class="aop.test.BeanB"/>    
    5.      <bean id="BeforeAdvice" class="aop.test.BeforeAdvice"></bean>  
    6.     
    7.      <bean class="org.springframework.aop.framework.autoproxy.  
    8.                        BeanNameAutoProxyCreator">  
    9.          <property name="beanNames">  
    10.              <list>  
    11.                  <value>Test*</value>  
    12.              </list>  
    13.          </property>  
    14.          <property name="interceptorNames">  
    15.              <list>  
    16.                  <value>BeforeAdvice</value>  
    17.              </list>  
    18.          </property>  
    19.      </bean>  
    20.  </beans>  

      運行主類,輸出結果如下:

    AutoProxy1

      可以看到,在主類TestMain中,我們是直接從Spring IoC容器中獲取收管Bean而不是像以前那樣從ProxyFactoryBean中獲取代理,但是我們的前置通知BeforeAdvice仍然在 TestBeanA對象的MyMethod()方法執行前被觸發,這說明我們的自動代理正在工作。

     

    2、使用DefaultAdvisorAutoProxyCreator

      DefaultAdvisorAutoProxyCreator允許我們只需定義相應的Advisor通知者,就可以完成自動代理。配 置好DefaultAdvisorAutoProxyCreator受管Bean后,它會自動查找配置文件中定義的Advisor,并將它們作用于所有的 Bean。

    修改例程4.10的配置文件,使用DefaultAdvisorAutoProxyCreator來完成自動代理。完成后配置文件代碼如下(本例完整工程代碼見例程4.11):

    1. <?xml version="1.0" encoding="UTF-8"?>  
    2. <beans ……>  
    3.      <bean id="TestBeanA" class="aop.test.TestBeanA" />  
    4.      <bean id="BeanB" class="aop.test.BeanB" />  
    5.      <bean id="BeforeAdvice" class="aop.test.BeforeAdvice"/>  
    6.      <bean class="org.springframework.aop.framework.autoproxy.  
    7.                    DefaultAdvisorAutoProxyCreator" />  
    8.     
    9.     <bean class="org.springframework.aop.support.NameMatchMethod  
    10.                                           PointcutAdvisor">  
    11.          <property name="advice" ref="BeforeAdvice" />  
    12.          <property name="mappedNames">  
    13.              <list>  
    14.                  <value>*Method*</value>  
    15.              </list>  
    16.          </property>  
    17.      </bean>      
    18.  </beans>  

      運行主類輸出結果如下:

    AutoProxy2

    from:http://www.itstrike.cn/html/Java/Springjiaocheng/200812/02-1427.html

    posted on 2008-12-02 20:20 墻頭草 閱讀(349) 評論(0)  編輯  收藏 所屬分類: Spring
    人人游戲網 軟件開發網 貨運專家
    主站蜘蛛池模板: 中文字幕免费视频一| 97超高清在线观看免费视频| 99久热只有精品视频免费观看17| 亚洲综合国产一区二区三区| 一级免费黄色大片| 日本媚薬痉挛在线观看免费| 亚洲va中文字幕| 永久免费AV无码网站在线观看| 亚洲精品无码久久久久秋霞| 在线观看成人免费| 亚洲AV无码一区二区乱子仑| 国产aa免费视频| 一级特级aaaa毛片免费观看| 亚洲色欲久久久综合网东京热 | 亚洲国产AV无码一区二区三区| 拍拍拍又黄又爽无挡视频免费| 亚洲国产精品无码久久九九大片| 国产精品免费看香蕉| 窝窝影视午夜看片免费| 亚洲AV无码国产精品色午友在线 | 亚洲人成网站在线观看青青| 国产成人自产拍免费视频| 久久亚洲精品视频| 啦啦啦完整版免费视频在线观看 | 羞羞漫画页面免费入口欢迎你 | 男人的天堂亚洲一区二区三区| 亚洲国产欧美一区二区三区| 亚洲精品国产福利一二区| 最新久久免费视频| 亚洲乱码在线视频| 亚洲Aⅴ无码一区二区二三区软件| 麻豆一区二区三区蜜桃免费| 亚洲成A人片在线观看无码不卡| 亚洲电影免费观看| 西西人体大胆免费视频| 亚洲av综合avav中文| 国产va精品免费观看| ssswww日本免费网站片| 亚洲国产精品成人精品软件| 免费萌白酱国产一区二区| 久草福利资源网站免费|