當前位置:才華齋>計算機>java語言>

講解Java的Spring框架中的AOP實現

java語言 閱讀(2.54W)

簡介

講解Java的Spring框架中的AOP實現

面向切面程式設計(AOP)提供另外一種角度來思考程式結構,通過這種方式彌補了面向物件程式設計(OOP)的不足。 除了類(classes)以外,AOP提供了 切面。切面對關注點進行模組化,例如橫切多個型別和物件的事務管理。 (這些關注點術語通常稱作 橫切(crosscutting) 關注點。)

Spring的一個關鍵的元件就是 AOP框架。 儘管如此,Spring IoC容器並不依賴於AOP,這意味著你可以自由選擇是否使用AOP,AOP提供強大的中介軟體解決方案,這使得Spring IoC容器更加完善。

Spring 2.0 AOP:

Spring 2.0 引入了一種更加簡單並且更強大的方式來自定義切面,使用者可以選擇使用基於模式(schema-based)的方式或者使用@AspectJ註解。 對於新的應用程式,如果使用者使用Java 5開發,我們推薦使用者使用@AspectJ風格,否則可以使用基於模式的風格。 這兩種風格都完全支援通知(Advice)型別和AspectJ的切入點語言,雖然實際上仍然使用Spring AOP進行織入(Weaving)。

本章主要討論Spring 2.0對基於模式和基於@AspectJ的AOP支援。 Spring 2.0完全保留了對Spring 1.2的向下相容性,下一章 將討論Spring 1.2 API所提供的底層的AOP支援。

Spring中所使用的AOP:

提供宣告式企業服務,特別是為了替代EJB宣告式服務。 最重要的服務是 宣告性事務管理(declarative transaction management) , 這個服務建立在Spring的抽象事務管理(transaction abstraction)之上。

允許使用者實現自定義的.切面,用AOP來完善OOP的使用。

例項

我們經常會用到的有如下幾種

1、基於代理的AOP

2、純簡單java物件切面

3、@Aspect註解形式的

4、注入形式的Aspcet切面

下面我們就一個一個來應用吧.

下面先寫一下幾個基本的類。

介面類:

/** * 定義一個介面 */ public interface Sleepable { /** * 睡覺方法 */ void sleep(); }

實現類:

/** * 本人實現睡覺介面 */ public class ChenLliNa implements Sleepable { @Override public void sleep() { // TODO Auto-generated method stub tln("乖,該睡覺了!"); } }

增強類:

/** * 定義一個睡眠的增強 同時實現前置 和後置 */ public class SleepHelper implements MethodBeforeAdvice, AfterReturningAdvice { @Override public void afterReturning(Object returnValue, Method method, Object[] args, Object target) throws Throwable { tln("睡覺前要敷面膜"); } @Override public void before(Method method, Object[] args, Object target) throws Throwable { tln("睡覺後要做美夢"); } }

一、基於代理的AOP

如配置檔案中:

pattern屬性指定了正則表示式,他匹配所有的sleep方法

使用ultPointcutAdvisor的目的是為了使切點和增強結合起來形成一個完整的切面

最後配置完後通過yFactoryBean產生一個最終的代理物件。

二、純簡單java物件切面

純簡單java物件切面這話怎麼說呢,在我看來就是相對於第一種配置,不需要使用代理,,而是通過spring的內部機制去自動掃描,這時候我們的配置檔案就該如下修改:

是不是相對於第一種簡單了許多,不用再去配置代理了。

三、@Aspect註解形式

根據我們的經驗也知道,註解的形式相對於配置檔案是簡單一些的,這時候需要在已有的方法或類上家註解:

/** * 通過註解的方式 新增增強 */ @Aspect @Component public class SleepHelper03 { /*@Pointcut("execution(* ..*(..))")*/ @Pointcut("execution(* *p(..))") public void sleeppoint(){} @Before("sleeppoint()") public void beforeSleep(){ tln("睡覺前要敷面膜"); } @AfterReturning("sleeppoint()") public void afterSleep(){ tln("睡覺後要做美夢"); }

配置檔案中只需寫:

四、注入形式的Aspcet切面

個人感覺這個是最簡單的也是最常用的,也是最靈活的。配置檔案如下:

配置檔案中提到的SleepHelper02類如下:

/** * 通過註解的方式 新增增強 */ public class SleepHelper02 { public void beforeSleep(){ tln("睡覺前要敷面膜"); } public void afterSleep(){ tln("睡覺後要做美夢"); } }

是不是看上去都很簡單呀,這樣是不是大家都會使用spring aop了?!

關於如何呼叫,這裡寫了幾個測試類,可以看一下,基本都一樣:

/** * 配置檔案 spring_ 通過代理 */ @Test public void test(){ ApplicationContext ct = new ClassPathXmlApplicationContext("spring_"); Sleepable sleeper =(Sleepable) ean("linaProxy"); p(); } /** * 配置檔案 spring_aop_ 簡答的java物件 */ @Test public void test01(){ ApplicationContext ct = new ClassPathXmlApplicationContext("spring_aop_"); Sleepable sleeper = (Sleepable)ean("lina"); p(); } /** * 配置檔案 spring_aop_ 通過aspect註解 */ @Test public void test03(){ ApplicationContext ct = new ClassPathXmlApplicationContext("spring_aop_"); Sleepable sleeper = (Sleepable)ean("lina"); p(); } /** * 配置檔案 spring_aop_ 通過apsect配置檔案 * @author 陳麗娜 * @version 2015年5月31日上午10:09:37 */ @Test public void test02(){ ApplicationContext ct = new ClassPathXmlApplicationContext("spring_aop_"); Sleepable sleeper = (Sleepable)ean("lina"); p(); }

通過測試類可以看出,不管以什麼樣的方式來實現aop他們的使用都是沒有差別的,這幾個測試類的結果都是一樣的: