hongyunxp

            BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
            2 隨筆 :: 2 文章 :: 1 評論 :: 0 Trackbacks

           

          摘要 面向方面編程(AOP)是面向?qū)ο缶幊蹋∣OP)的一種擴(kuò)展技術(shù),能夠很好的解決橫切關(guān)注點問題以及相關(guān)的設(shè)計難題來實現(xiàn)松散耦合。Spring AOP 是 AOP 技術(shù)的一種實現(xiàn)。本文介紹了AOP 概念,然后詳細(xì)討論了如何利用Spring AOP 開發(fā)AOP 程序,最后展望了Spring AOP 的前景。

            關(guān)鍵詞 AOP Spring AOP Java

            引言

            AOP(Aspected Oriented Programming)是一種新興的編程技術(shù)。它可以解決OOP和過程化方法不能夠很好解決的橫切(crosscut)問題,如:事務(wù)、安全、日志等橫切關(guān)注。當(dāng)未來系統(tǒng)變得越來越復(fù)雜,橫切關(guān)注點就成為一個打問題的時候,AOP就可以很輕松的解決橫切關(guān)注點這個問題,使得AOP編程成為。Spring 是基于J2EE的輕量級開源開發(fā)框架,其中Spring AOP組件實現(xiàn)了面向方面編程。

            AOP 概述

            面向方面編程 (AOP) 提供從另一個角度來考慮程序結(jié)構(gòu)以完善面向?qū)ο缶幊蹋∣OP)。 面向?qū)ο髮?yīng)用程序分解成各個層次的對象,而AOP將程序分解成各個方面或者說關(guān)注點 。這使得可以模塊化諸如事務(wù)管理等這些橫切多個對象的關(guān)注點。

            1、AOP 基本概念

            方面(Aspect): 一個關(guān)注點的模塊化,這個關(guān)注點實現(xiàn)可能另外橫切多個對象。事務(wù)管理是J2EE應(yīng)用中一個很好的橫切關(guān)注點例子。方面用Spring的 Advisor或攔截器實現(xiàn)。

            連接點(Joinpoint): 程序執(zhí)行過程中明確的點,如方法的調(diào) 用或特定的異常被拋出。

            通知(Advice): 在特定的連接點,AOP框架執(zhí)行的動作。各種類 型的通知包括“around”、“before”和“throws”通知。通知類型將在下面討論。許多AOP框架 包括Spring都是以攔截器做通知模型,維護(hù)一個“圍繞”連接點的攔截器鏈。

            切入點(Pointcut): 指定一個通知將被引發(fā)的一系列連接點 的集合。AOP框架必須允許開發(fā)者指定切入點:例如,使用正則表達(dá)式。

            引入(Introduction): 添加方法或字段到被通知的類。 Spring允許引入新的接口到任何被通知的對象。例如,你可以使用一個引入使任何對象實現(xiàn) IsModified接口,來簡化緩存。

            目標(biāo)對象(Target Object): 包含連接點的對象。也被稱作 被通知或被代理對象。

            AOP代理(AOP Proxy): AOP框架創(chuàng)建的對象,包含通知。 在Spring中,AOP代理可以是JDK動態(tài)代理或者CGLIB代理。

            織入(Weaving): 組裝方面來創(chuàng)建一個被通知對象。這可以在編譯時 完成(例如使用AspectJ編譯器),也可以在運行時完成。Spring和其他純Java AOP框架一樣, 在運行時完成織入。

            Spring AOP 介紹

            Spring的一個關(guān)鍵組件就是AOP框架。 Spring IoC容器(BeanFactory 和ApplicationContext)并不依賴于AOP, 這意味著如果你不需要使用,AOP可以不用,AOP完善了Spring IoC,使之成為一個有效的中間件解決方案。

            Spring AOP 是Spring 框架的重要組成部分,它實現(xiàn)了AOP聯(lián)盟約定的接口。Spring AOP 是由純Java開發(fā)完成的。Spring AOP 只實現(xiàn)了方法級別的連接點,在J2EE應(yīng)用中,AOP攔截到方法級的操作已經(jīng)足夠。OOP倡導(dǎo)的是基于setter/getter 的方法訪問,而非直接訪問域,而Spring 有足夠理由僅僅提供方法級的連接點。為了使控制反轉(zhuǎn)(IoC)很方便的使用到非常健壯、靈活的企業(yè)服務(wù),則需要Spring AOP 的實現(xiàn)。Spring AOP 在運行時才創(chuàng)建Advice 對象。Spring AOP的優(yōu)點如下:

            ·允許開發(fā)者使用聲明式企業(yè)服務(wù),比如事務(wù)服務(wù)、安全性服務(wù)。

            ·開發(fā)者可以開發(fā)滿足業(yè)務(wù)需求的自定義方面。

            ·開發(fā)Spring AOP Advice 很方便,可以借助代理類快速搭建Spring AOP 應(yīng)用。

            使用Spring AOP松散耦合

            1、創(chuàng)建通知

            為實現(xiàn)AOP,開發(fā)者需要開發(fā)AOP 通知(Advice)。AOP 通知(Advice) 包含了方面(Aspect)的邏輯。當(dāng)創(chuàng)建一個Advice 對象的時候,你就編寫了實現(xiàn)橫切(cross-cutting)功能。 Spring 的連接點是用方法攔截器實現(xiàn)的,這就意味著你編寫的Spring AOP 通知將在方法調(diào)用的不同點組入進(jìn)程序中。由于在調(diào)用一個方法時有幾個不同的時間點,Spring 可以在不同的時間點組入進(jìn)程序。Spring AOP中,提供了四種通知的接口: MethodBeforeAdvice 用于在目標(biāo)方法調(diào)用前觸發(fā);AfterReturningAdvice 用于在目標(biāo)方法調(diào)用后觸發(fā);ThrowsAdvice 用于在目標(biāo)方法拋出異常時觸發(fā);MethodInterceptor 用于實現(xiàn) Around 通知(Advice),在目方法執(zhí)行的前后觸發(fā)。

            如果要實現(xiàn)相應(yīng)功能,則需要實現(xiàn)上述對應(yīng)的接口。例如:實現(xiàn)Before 通知(Advice)需要實現(xiàn)方法 void before(Method method, Object[] args, Object target) ,實現(xiàn) After 通知(Advice) 需要實現(xiàn)方法 void afterReturning (Method method, Object[] args, Object target)。

            2、在Spring 中定義切入點

            在不能明確調(diào)用方法的時候,通知就很不實用。切入點則可以決定特定的類,特定的方法是否匹配特定標(biāo)準(zhǔn)。如果某匹配,則通知將應(yīng)用到此方法上。Spring 切入點允許用很靈活的方式將通知組織進(jìn)我們的類中。Spring 中的切入點框架的核心是Pointcut接口,此接口允許我們定義組入通知中的類和方法。許多方面是通過一系列的通知和切入點組合來定義。

            在Spring中,一個advisor就是一個方面的完整的模塊化表示。Spring提供了PointcutAdvisor接口把通知和切入點組合成一個對象。Spring中很多內(nèi)建的切入點都有對應(yīng)的PointcutAdvisor,這使得你可以很方便在一個地方管理切入點和通知。Spring中的切入點分為兩類:靜態(tài)和動態(tài)。因為靜態(tài)切入點的性能要優(yōu)于動態(tài)切入點,所以優(yōu)先考慮使用。Spring 為我們提供創(chuàng)建靜態(tài)切入點很實用的類StaticMethodMatherPointcut。在這個類中,我們只需要關(guān)心setMappedName和setMappedNams方法。你可以使用具體的類名,也可以使用通配符。如:設(shè)置mappedName屬性為set* 則匹配所有的set方法。Spring還提供了另通過正則表達(dá)式來創(chuàng)建靜態(tài)切入點的實用類RegexpMethodPointcut。通過使用Perl樣式的正則表達(dá)式來定義你感興趣的方法。當(dāng)切入點需要運行時參數(shù)值來執(zhí)行通知時,這時就需要使用動態(tài)切入點。Spring提供了一個內(nèi)建的動態(tài)切入點:ControlFlowPointcut,此切入點匹配基于當(dāng)前線程的調(diào)用堆棧。我們可以在只有在當(dāng)前線程執(zhí)行的執(zhí)行時找到特定的類和特定的方法才返回true。使用動態(tài)切入點有很大的性能損耗。大多數(shù)的切入點可以靜態(tài)確定,我們很少有機(jī)會創(chuàng)建動態(tài)切入點。為了增加可切入點的可重用性,Spring 提供了切入點上的集合操作——交集和合并。

            3、用ProxyFactoryBean創(chuàng)建AOP代理

            ProxyFactoryBean,和其他Spring的 FactoryBean實現(xiàn)一樣,引入一個間接的層次。如果你定義一個名字為myfactory的ProxyFactoryBean, 引用myfactory的對象所看到的不是ProxyFactoryBean 實例本身,而是由實現(xiàn)ProxyFactoryBean的類的 getObject()方法所創(chuàng)建的對象。這個方法將創(chuàng)建一個包裝了目標(biāo)對象 的AOP代理。使用ProxyFactoryBean或者其他IoC可知的類來創(chuàng)建AOP代理的最重要的優(yōu)點之一是IoC可以管理通知和切入點。這是一個非常的強(qiáng)大的功能,能夠?qū)崿F(xiàn)其他AOP框架很難實現(xiàn)的特定的方法。例如,一個通知本身可以引用應(yīng)用對象(除了目標(biāo)對象, 它在任何AOP框架中都可以引用應(yīng)用對象),這完全得益于依賴注入所提供的可插入性。通常,我們不需要ProxyFactoryBean的全部功能,因為我們常常只對一個方面感興趣: 例如,事務(wù)管理。當(dāng)我們僅僅對一個特定的方面感興趣時,我們可以使用許多便利的工廠來創(chuàng)建AOP代理,如:TransactionProxyFactoryBean。

            4、自動代理

            在應(yīng)用較小時,只有很少類需要被通知的時,ProxyFactoryBean 可以很好的工作。當(dāng)有許多類需要通知的時,顯示的創(chuàng)建每個代理就顯得很繁瑣。幸運的是Spring提供了是使用自動通過容器來創(chuàng)建代理。這時,就只需要配置一個Bean來做繁瑣的工作。Spring提供了兩個類實現(xiàn)自動代理:BeanNameAutoProxyCreator和DefaultAdvisorAutoProxyCreator。BeanNameAutoProxyCreator為匹配名字的Bean產(chǎn)生代理,它可以使用在將一個或者多個方面應(yīng)用在命名相似的Bean中。自動代理框架假設(shè)代理將要暴露出什么接口。如果目標(biāo)Bean沒有實現(xiàn)任何接口,這時就會動態(tài)產(chǎn)生一個子類。而更強(qiáng)大的自動代理是DefaultAdvisorAutoProxyCreator,你所需要做的是在BeanFactory中包含它的配置。這個類的奇妙之處在于他使用實現(xiàn)了BeanPostProcessor接口。在Bean定義被加載倒Spring容器中后,DefaultAdvisorAutoProxyCreator將搜索上下文中的Advisor,最后它將Advisor應(yīng)用到匹配Advisor切入點的Bean中。這個代理只對Advisor起作用,它需要通過Advisor來得到需要通知的Bean。元數(shù)據(jù)自動代理(MetaData AutoProxy)。元數(shù)據(jù)自動代理配置依賴于源代碼屬性而不是外部XML配置文件。這可以非常方便的使源代碼和AOP元數(shù)據(jù)組織在同一個地方。元數(shù)據(jù)自動代理最常用的地方是用來聲明事務(wù)。Spring提供了很強(qiáng)的框架來通過AOP框架來聲明事務(wù)。這提供了在EJB使用聲明式事務(wù)的相同功能。

            結(jié)論

            AOP 是面向?qū)ο缶幊痰挠辛ρa充。通過方面就可以聚合在應(yīng)用中行為形成可重用模塊。

            通過程序可以實現(xiàn)怎樣和在什么地方來調(diào)用這些行為。這可以減少代碼重復(fù),并使你更加關(guān)注業(yè)務(wù)邏輯。Spring 提供了AOP框架來實現(xiàn)調(diào)用方法時加入方面。在AOP框架中可以很方便的使用預(yù)定義的靜態(tài)切入點來定義被調(diào)用的類和方法。我們需要通過Spring提供的代理類來產(chǎn)生代理對象,可以使用ProxyFactoryBean也可以使用自動代理。Spring AOP 的編程方式模塊化了橫向關(guān)注點的實現(xiàn),提供了一個更好更快的軟件開發(fā)方式。在軟件結(jié)構(gòu)日益擴(kuò)大,結(jié)構(gòu)日益復(fù)雜的今天,Spring AOP 將會發(fā)揮越來越重要的作用。
          posted on 2007-05-20 16:35 徐洪云 閱讀(188) 評論(0)  編輯  收藏

          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 昔阳县| 清河县| 镇坪县| 东明县| 山东| 紫金县| 聂拉木县| 莲花县| 青海省| 宣化县| 工布江达县| 晋中市| 丰城市| 渝北区| 泽库县| 丰原市| 靖安县| 池州市| 拜泉县| 响水县| 上高县| 大庆市| 长治市| 天气| 灵寿县| 城固县| 芒康县| 天全县| 济宁市| 肥西县| 克拉玛依市| 尉犁县| 建宁县| 米泉市| 平塘县| 伽师县| 原平市| 大冶市| 库尔勒市| 南康市| 怀集县|