Spring AOP 和 IOC 容器入門 ![]() |
![]() |
![]() |
級別: 初級 Naveen Balani (naveenbalani@rediffmail.com), 技術(shù)架構(gòu)師, Webify Solutions 2005 年 8 月 18 日 在這由三部分組成的介紹 Spring 框架的系列文章的第一期中,將開始學(xué)習(xí)如何用 Spring 技術(shù)構(gòu)建輕量級的、強(qiáng)壯的 J2EE 應(yīng)用程序。developerWorks 的定期投稿人 Naveen Balani 通過介紹 Spring 框架開始了他由三部分組成的 Spring 系列,其中還將介紹 Spring 面向方面的編程(AOP)和控制反轉(zhuǎn)(IOC)容器。 Spring 是一個開源框架,是為了解決企業(yè)應(yīng)用程序開發(fā)復(fù)雜性而創(chuàng)建的。框架的主要優(yōu)勢之一就是其分層架構(gòu),分層架構(gòu)允許您選擇使用哪一個組件,同時為 J2EE 應(yīng)用程序開發(fā)提供集成的框架。 在這篇由三部分組成的 Spring 系列 的第 1 部分中,我將介紹 Spring 框架。我先從框架底層模型的角度描述該框架的功能,然后將討論兩個最有趣的模塊:Spring 面向方面編程(AOP)和控制反轉(zhuǎn) (IOC) 容器。接著將使用幾個示例演示 IOC 容器在典型應(yīng)用程序用例場景中的應(yīng)用情況。這些示例還將成為本系列后面部分進(jìn)行的展開式討論的基礎(chǔ),在本文的后面部分,將介紹 Spring 框架通過 Spring AOP 實現(xiàn) AOP 構(gòu)造的方式。 請參閱 下載,下載 Spring 框架和 Apache Ant,運(yùn)行本系列的示例應(yīng)用程序需要它們。 Spring 框架是一個分層架構(gòu),由 7 個定義良好的模塊組成。Spring 模塊構(gòu)建在核心容器之上,核心容器定義了創(chuàng)建、配置和管理 bean 的方式,如圖 1 所示。 圖 1. Spring 框架的 7 個模塊 ![]() 組成 Spring 框架的每個模塊(或組件)都可以單獨(dú)存在,或者與其他一個或多個模塊聯(lián)合實現(xiàn)。每個模塊的功能如下:
Spring 框架的功能可以用在任何 J2EE 服務(wù)器中,大多數(shù)功能也適用于不受管理的環(huán)境。Spring 的核心要點是:支持不綁定到特定 J2EE 服務(wù)的可重用業(yè)務(wù)和數(shù)據(jù)訪問對象。毫無疑問,這樣的對象可以在不同 J2EE 環(huán)境 (Web 或 EJB)、獨(dú)立應(yīng)用程序、測試環(huán)境之間重用。
控制反轉(zhuǎn)模式(也稱作依賴性介入)的基本概念是:不創(chuàng)建對象,但是描述創(chuàng)建它們的方式。在代碼中不直接與對象和服務(wù)連接,但在配置文件中描述哪一個組件需要哪一項服務(wù)。容器 (在 Spring 框架中是 IOC 容器) 負(fù)責(zé)將這些聯(lián)系在一起。 在典型的 IOC 場景中,容器創(chuàng)建了所有對象,并設(shè)置必要的屬性將它們連接在一起,決定什么時間調(diào)用方法。下表列出了 IOC 的一個實現(xiàn)模式。
Spring 框架的 IOC 容器采用類型 2 和類型3 實現(xiàn)。 面向方面的編程,即 AOP,是一種編程技術(shù),它允許程序員對橫切關(guān)注點或橫切典型的職責(zé)分界線的行為(例如日志和事務(wù)管理)進(jìn)行模塊化。AOP 的核心構(gòu)造是方面,它將那些影響多個類的行為封裝到可重用的模塊中。 AOP 和 IOC 是補(bǔ)充性的技術(shù),它們都運(yùn)用模塊化方式解決企業(yè)應(yīng)用程序開發(fā)中的復(fù)雜問題。在典型的面向?qū)ο箝_發(fā)方式中,可能要將日志記錄語句放在所有方法和 Java 類中才能實現(xiàn)日志功能。在 AOP 方式中,可以反過來將日志服務(wù)模塊化,并以聲明的方式將它們應(yīng)用到需要日志的組件上。當(dāng)然,優(yōu)勢就是 Java 類不需要知道日志服務(wù)的存在,也不需要考慮相關(guān)的代碼。所以,用 Spring AOP 編寫的應(yīng)用程序代碼是松散耦合的。 AOP 的功能完全集成到了 Spring 事務(wù)管理、日志和其他各種特性的上下文中。
Spring 設(shè)計的核心是
bean 工廠的概念是 Spring 作為 IOC 容器的基礎(chǔ)。IOC 將處理事情的責(zé)任從應(yīng)用程序代碼轉(zhuǎn)移到框架。正如我將在下一個示例中演示的那樣,Spring 框架使用 JavaBean 屬性和配置數(shù)據(jù)來指出必須設(shè)置的依賴關(guān)系。 因為 清單 1. XmlBeanFactory
在 XML 文件中定義的 Bean 是被消極加載的,這意味在需要 bean 之前,bean 本身不會被初始化。要從 清單 2. getBean()
每個 bean 的定義都可以是 POJO (用類名和 JavaBean 初始化屬性定義) 或
理解控制反轉(zhuǎn)最簡單的方式就是看它的實際應(yīng)用。在對由三部分組成的 Spring 系列 的第 1 部分進(jìn)行總結(jié)時,我使用了一個示例,演示了如何通過 Spring IOC 容器注入應(yīng)用程序的依賴關(guān)系(而不是將它們構(gòu)建進(jìn)來)。 我用開啟在線信用帳戶的用例作為起點。對于該實現(xiàn),開啟信用帳戶要求用戶與以下服務(wù)進(jìn)行交互:
對于這個示例,我假設(shè)服務(wù)已經(jīng)存在,理想的情況是用松散耦合的方式把它們集成在一起。以下清單顯示了三個服務(wù)的應(yīng)用程序接口。 清單 3. CreditRatingInterface
清單 3 所示的信用級別評定接口提供了信用歷史信息。它需要一個包含客戶信息的 清單 4. CreditLinkingInterface
信用鏈接接口將信用歷史信息與銀行信息(如果需要的話)連接在一起,并插入用戶的信用卡信息。信用鏈接接口是一個遠(yuǎn)程服務(wù),它的查詢是通過 清單 5. EmailInterface
這些接口就位之后,接下來要考慮的就是如何用松散耦合方式將它們集成在一起。在 清單 6 中可以看到信用卡帳戶用例的實現(xiàn)。 注意,所有的 setter 方法都是由 Spring 的配置 bean 實現(xiàn)的。所有的依賴關(guān)系 (也就是三個接口)都可以由 Spring 框架用這些 bean 注入。
要運(yùn)行示例應(yīng)用程序,首先必須 下載 Spring 框架 及其所有依賴文件。接下來,將框架釋放到(比如說)磁盤 c:\,這會創(chuàng)建 C:\spring-framework-1.2-rc2 (適用于當(dāng)前發(fā)行版本) 這樣的文件夾。在繼續(xù)后面的操作之前,還必須下載和釋放 Apache Ant。 接下來,將源代碼釋放到文件夾,例如 c:\ 盤,然后創(chuàng)建 SpringProject。將 Spring 庫(即 C:\spring-framework-1.2-rc2\dist 下的 spring.jar 和 C:\spring-framework-1.2-rc2\lib\jakarta-commons 下的 commons-logging.jar)復(fù)制到 SpringProject\lib 文件夾中。完成這些工作之后,就有了必需的構(gòu)建依賴關(guān)系集。 打開命令提示符,將當(dāng)前目錄切換到 SpringProject,在命令提示符中輸入以下命令: 這會構(gòu)建并運(yùn)行 清單 8. 裝入 Spring 配置文件
在這篇由三部分組成的 Spring 系列 的第一篇文章中,我介紹了 Spring 框架的基礎(chǔ)。我從討論組成 Spring 分層架構(gòu)的 7 個模塊開始,然后深入介紹了其中兩個模塊:Spring AOP 和 IOC 容器。 由于學(xué)習(xí)的最佳方法是實踐,所以我用一個工作示例介紹了 IOC 模式 (像 Spring 的 IOC 容器實現(xiàn)的那樣)如何用松散耦合的方式將分散的系統(tǒng)集成在一起。在這個示例中可以看到,將依賴關(guān)系或服務(wù)注入工作中的信用卡帳戶應(yīng)用程序,要比從頭開始構(gòu)建它們?nèi)菀椎枚唷?/p> 請繼續(xù)關(guān)注這一系列的下一篇文章,我將在這里學(xué)習(xí)的知識基礎(chǔ)上,介紹 Spring AOP 模塊如何在企業(yè)應(yīng)用程序中提供持久支持,并讓您開始了解 Spring MVC 模塊和相關(guān)插件。 |