Posted on 2010-03-27 23:11
陜西BOY 閱讀(329)
評論(0) 編輯 收藏
Spring的AOP
-
AOP概述
-
Aspect Oriented Programming(AOP)即“面向切面編程”。AOP針對業務處理過程中的切面進行提取,它所面對的是處理過程中的某個步驟或階段,以獲得邏輯過程中各部分之間低耦合性的隔離效果。AOP的兩個主要特點:
-
Spring框架下的AOP
-
Spring中提供的內置AOP支持,是基于動態AOP機制實現。從技術角度來講,所謂動態AOP,即通過動態Proxy模式,在目標對象的方法調用前后插入相應的處理代碼。而Spring AOP中的動態Proxy模式,則是基于Java Dynamic Proxy(面向Interface)和CGLib(面向Class)實現。
-
Spring Framework中的“事務管理”服務,實際上是借助AOP機制完成。
-
AOP概念,這些術語不是Spring特有的。 不幸的是,Spring術語并不是特別的直觀;如果Spring使用自己的術語,將會變得更加令人困惑。
-
切面(Aspect): 一個關注點的模塊化,這個關注點可能會橫切多個對象。事務管理是J2EE應用中一個關于橫切關注點的很好的例子。 在Spring AOP中,切面可以使用通用類(基于模式的風格) 或者在普通類中以 @Aspect
注解(@AspectJ
風格)來實現。
-
連接點(Joinpoint): 在程序執行過程中某個特定的點,比如某方法調用的時候或者處理異常的時候。 在Spring AOP中,一個連接點 總是 代表一個方法的執行。 通過聲明一個org.aspectj.lang.JoinPoint
類型的參數可以使通知(Advice)的主體部分獲得連接點信息。
-
通知(Advice): 在切面的某個特定的連接點(Joinpoint)上執行的動作。通知有各種類型,其中包括“around”、“before”和“after”等通知。 通知的類型將在后面部分進行討論。許多AOP框架,包括Spring,都是以攔截器做通知模型, 并維護一個以連接點為中心的攔截器鏈。
-
切入點(Pointcut): 匹配連接點(Joinpoint)的斷言。通知和一個切入點表達式關聯,并在滿足這個切入點的連接點上運行(例如,當執行某個特定名稱的方法時)。 切入點表達式如何和連接點匹配是AOP的核心:Spring缺省使用AspectJ切入點語法。
-
引入(Introduction): (也被稱為內部類型聲明(inter-type declaration))。聲明額外的方法或者某個類型的字段。 Spring允許引入新的接口(以及一個對應的實現)到任何被代理的對象。 例如,你可以使用一個引入來使bean實現 IsModified
接口,以便簡化緩存機制。
-
目標對象(Target Object): 被一個或者多個切面(aspect)所通知(advise)的對象。也有人把它叫做 被通知(advised) 對象。 既然Spring AOP是通過運行時代理實現的,這個對象永遠是一個 被代理(proxied) 對象。
-
AOP代理(AOP Proxy): AOP框架創建的對象,用來實現切面契約(aspect contract)(包括通知方法執行等功能)。 在Spring中,AOP代理可以是JDK動態代理或者CGLIB代理。 注意:Spring 2.0最新引入的基于模式(schema-based)風格和@AspectJ注解風格的切面聲明,對于使用這些風格的用戶來說,代理的創建是透明的。
-
織入(Weaving): 把切面(aspect)連接到其它的應用程序類型或者對象上,并創建一個被通知(advised)的對象。 這些可以在編譯時(例如使用AspectJ編譯器),類加載時和運行時完成。 Spring和其他純Java AOP框架一樣,在運行時完成織入。
其中通知(Advice)的類型:
-
前置通知(Before advice): 在某連接點(join point)之前執行的通知,但這個通知不能阻止連接點前的執行(除非它拋出一個異常)。
-
返回后通知(After returning advice): 在某連接點(join point)正常完成后執行的通知:例如,一個方法沒有拋出任何異常,正常返回。
-
拋出異常后通知(After throwing advice): 在方法拋出異常退出時執行的通知。
-
后通知(After (finally) advice): 當某連接點退出的時候執行的通知(不論是正常返回還是異常退出)。
-
環繞通知(Around Advice): 包圍一個連接點(join point)的通知,如方法調用。這是最強大的一種通知類型。 環繞通知可以在方法調用前后完成自定義的行為。它也會選擇是否繼續執行連接點或直接返回它們自己的返回值或拋出異常來結束執行。
環繞通知是最常用的一種通知類型。大部分基于攔截的AOP框架,例如Nanning和JBoss4,都只提供環繞通知。
跟AspectJ一樣,Spring提供所有類型的通知,我們推薦你使用盡量簡單的通知類型來實現需要的功能。 例如,如果你只是需要用一個方法的返回值來更新緩存,雖然使用環繞通知也能完成同樣的事情, 但是你最好使用After returning通知而不是環繞通知。 用最合適的通知類型可以使得編程模型變得簡單,并且能夠避免很多潛在的錯誤。 比如,你不需要調用 JoinPoint
(用于Around Advice)的 proceed()
方法,就不會有調用的問題。
在Spring 2.0中,所有的通知參數都是靜態類型,因此你可以使用合適的類型(例如一個方法執行后的返回值類型)作為通知的參數而不是使用一個對象數組。
切入點(pointcut)和連接點(join point)匹配的概念是AOP的關鍵,這使得AOP不同于其它僅僅提供攔截功能的舊技術。 切入點使得定位通知(advice)可獨立于OO層次。 例如,一個提供聲明式事務管理的around通知可以被應用到一組橫跨多個對象中的方法上(例如服務層的所有業務操作)。
-
下面是本人整理的AOP各個元素的示意圖:
-
