空間站

          北極心空

            BlogJava :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
            15 Posts :: 393 Stories :: 160 Comments :: 0 Trackbacks

          Spring 2.0 的重頭戲之一就是AspectJ 式 AOP 配置。 但是一定要通過對比,才能看到2.0式的AOP配置是如何跳出一片新天空的。

          1. 對比
          先看1.0的標準事務配置:

          Spring 2.0 的重頭戲之一就是AspectJ 式 AOP 配置。 但是一定要通過對比,才能看到2.0式的AOP配置是如何跳出一片新天空的。

          1. 對比
          先看1.0的標準事務配置:

          代碼
          1. <bean id="baseTxService" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean"  
          2.           abstract="true">  
          3.         <property name="transactionManager" ref="transactionManager"/>  
          4.         <property name="proxyTargetClass" value="true"/>  
          5.         <property name="transactionAttributes">  
          6.             <props>  
          7.                 <prop key="get*">PROPAGATION_REQUIRED,readOnly</prop>  
          8.                 <prop key="find*">PROPAGATION_REQUIRED,readOnly</prop>  
          9.                 <prop key="save*">PROPAGATION_REQUIRED</prop>  
          10.                 <prop key="remove*">PROPAGATION_REQUIRED</prop>  
          11.             </props>  
          12.         </property>  
          13.         <property name="preInterceptors">  
          14.             <list>  
          15.                 <ref bean="methodSecurityInterceptor"/>  
          16.             </list>  
          17.         </property>  
          18.  </bean>  
          19.  <bean id="bookManager" parent="baseTxService">  
          20.         <property name="target">  
          21.             <bean class="org.springside.bookstore.admin.manager.BookManager"/>  
          22.         </property>  
          23.  </bean>  

           

          再看2.0的新配置:

          代碼
          1. <aop:config proxy-target-class="true">  
          2.     <aop:advisor pointcut="execution(* yourpackagename..*Manager.*(..))" advice-ref="txAdvice"/>  
          3.     <aop:advisor pointcut="execution(* yourpackagename..*Manager.save(..))" advice-ref="fooAdvice"/>  
          4. </aop:config><tx:advice id="txAdvice" transaction-manager="transactionManager">  
          5.     <tx:attributes>  
          6.         <tx:method name="save*"/>  
          7.         <tx:method name="remove*"/>  
          8.         <tx:method name="*" read-only="true"/>  
          9.    </tx:attributes>  
          10. </tx:advice>  
          11.   
          12. <bean id="bookManager" class="org.springside.bookstore.commons.service.BookManager"/>  

           

          2.進步
          1. AOP的配置方式也AOP了。
          對比1.0的配置文件,因為下面2提到的限制,事關安全acegi methodSecurityInterceptor 攔截器要配置在關于事務的TransactionProxyFactoryBean的preInterceptors屬性里,這樣子就一點不AOP了,而2.0使用ponintcut expression,很AOP的配置一切Aspect。

          2. 1.0時,一個已經(jīng)AOP過的object不能再次被AOP。
          在Spring 1.0的文檔里Rod說,比如<bean id="bookManager" parent="baseTxService">已經(jīng)進行了一次AOP,如果想在這個Bean上再配一層AOP,比如要對方法執(zhí)行結(jié)果緩存,無論以1.0 還是2.0的方式定義,cglib方式是會報錯的,而基于接口的方式,結(jié)果不確定。

          3. BookManager能直接定義自己,而不是像1.0那樣作匿名內(nèi)部target。

          雖然在1.0時代的BeanNameAutoProxyCreator 達到類似作用,但只能用BeanName來匹配比較危險,沒有AspectJ的pointcut語法細致。

          3. 語法
          滿江紅翻譯的Spring參考文檔 6.3 schema-based AOP support 提供了aspect,advisor,advide三種組裝方法的解釋,其中aspect是aspectJ原裝,但稍復雜.

          唯一有點難懂的是pointcut里的語法,其實也很好學,Spring參考文檔6.2.3.4里有完整說明 ,其實一排子過去是

          代碼
          1. execution(modifiers-pattern? ret-type-pattern declaring-type-pattern? name-pattern(param-pattern) throws-pattern?)  
          其中帶問號的modifiers-pattern?(public/protected) 和 declaring-type-pattern? throws-pattern? 可以不填

           

          可見execution(* *..BookManager.save(..))

          第一顆* 代表ret-type-pattern 返回值可任意,
          *..BookManager 代表任意Pacakge里的BookManager類。
          如果寫成com.xyz.service.* 則代表com.xyz.service下的任意類
          com.xyz.service..* com.xyz.service則代表com.xyz.service及其子package下的任意類
          save代表save方法,也可以寫save* 代表saveBook()等方法
          (..) 匹配0個參數(shù)或者多個參數(shù)的,任意類型
          (x,..) 第一個參數(shù)的類型必須是X
          (x,,,s,..) 匹配至少4個參數(shù),第一個參數(shù)必須是x類型,第二個和第三個參數(shù)可以任意,第四個必須是s類型。

          注意name-pattern千萬不要寫成*..*Manager ,這樣子的話會把所有第三方類庫的Manager比如Spring的PlatformTranstationManager 也加入aop,非常危險。所以最好還是加上項目的package前綴,如org.springside





          引用
          對比1.0的配置文件,因為下面2提到的限制,事關安全acegi methodSecurityInterceptor 攔截器要配置在關于事務的TransactionProxyFactoryBean的preInterceptors屬性里,這樣子就一點不AOP了,而 2.0使用ponintcut expression,很AOP的配置一切Aspect。


          1其實可以

          代碼
          1. <bean id="autoProxyCreator"  
          2.           class="org.springframework.aop.framework.autoproxy.BeanNameAutoProxyCreator">  
          3.         <property name="interceptorNames">  
          4.             <list>  
          5.                 <value>security</value>  
          6.                 <value>tx</value>  
          7.             </list>  
          8.         </property>  
          9.         <property name="beanNames">  
          10.             <value>*Service</value>  
          11.         </property>  


          posted on 2007-08-09 15:18 蘆葦 閱讀(392) 評論(0)  編輯  收藏 所屬分類: Spring
          主站蜘蛛池模板: 琼结县| 峨山| 大洼县| 通渭县| 江孜县| 赫章县| 玛曲县| 荣成市| 额济纳旗| 连山| 遵化市| 准格尔旗| 三明市| 佳木斯市| 清流县| 明光市| 洪湖市| 商丘市| 舒兰市| 安新县| 德阳市| 那坡县| 东港市| 霍城县| 建始县| 嘉荫县| 南部县| 旌德县| 镇远县| 白城市| 祁连县| 扬州市| 永登县| 尤溪县| 舞钢市| 琼结县| 临夏县| 龙里县| 罗平县| 咸阳市| 合川市|