Spring中XML配置的12個技巧

 

Spring利用依賴注入可以獲得簡單而有效的測試能力。Spring beans,依賴關係,以及服務所需要的bean都將在配置文件中予以描述,配置文件一般採用XML格式。然而XML配置文件冗長而不易使用,在你進行一個使用了大量bean的大項目中它將變得難以閱讀和控制。

  在這篇文章中我將給你展示12種的有關Spring XML配置文件的最佳技巧。請注意另外一些因素,例如模型的設計,會影響到XML配置,但是這篇文章更關注於XML配置的可讀性和可操控性。

  1.避免使用自動裝配

  Spring可以通過bean類的自省來實現自動裝配依賴,這樣的話你就不必明確地描述bean的屬性或者構造函數的參數。根據屬性名稱活匹配類型,bean屬性可以自動進行裝配。而構造函數可以根據匹配類型自動裝配。你甚至可以設置自動裝配進行自動偵測,這樣Spring替你就會選擇一個合適的機制。請看下面的例子:

  Spring可以通過bean類的自省來實現自動裝配依賴,這樣的話你就不必明確地描述bean的屬性或者構造函數的參數。根據屬性名稱活匹配類型,bean屬性可以自動進行裝配。而構造函數可以根據匹配類型自動裝配。你甚至可以設置自動裝配進行自動偵測,這樣Spring替你就會選擇一個合適的機制。請看下面的例子:

  

      class="com.lizjason.spring.OrderService"autowire="byName"/>
  OrderService類的屬性名被用來和容器中的一個bean實例進行匹配。自動裝配會默默的保存一些類型信息並降低混亂。然而,由於它會犧牲掉這種配置的直觀性和可維護性,你在實際的項目中將不會用到它。許多指南和陳述材料都把它吹捧爲Spring的一個非常cool的特性,而沒有提到它的這個缺點。依我之見,就像Spring的對象池一樣,它更多了一些商業味道。它看起來好像可以使XML配置文件更精簡一些,但實際上卻增加其複雜性,尤其是在你的較大規模的工程中已經定義了很多bean的時候更是如此。Spring允許你混合使用自動和手動裝配,但是這種矛盾會使XML配置更加的令人費解。

  2.使用命名規範

  和Java編碼的理念一樣,在項目中始終用清晰的,描述性的,一致的命名規範對開發人員理解XML配置非常有用。拿bean ID舉例來說,你可以遵循Java類中屬性的命名規範。比如說,OrderServiceDAO的bean ID應該是orderServiceDAO。對於大項目來說,在bean ID前加包名來作爲前綴。

  3.使用簡化格式

  簡化格式有利於減少冗餘,因爲它把屬性值和引用作爲屬性,而不是子元素。看下面的例子:

  

class="com.lizjason.spring.OrderService">lizjason
  以上程序可以重新以簡化格式書寫爲:

  class="com.lizjason.spring.OrderService">value="lizjason"/> 簡化格式在1.2版本時已經可用了,但請注意不存在這種簡化格式不僅可以較少你的代碼輸入量,而且可以使XML配置更加的清晰。當你的配置文件中存在大量的bean定義時,它可以顯著地提高可讀性。4.儘量使用type而不是index去解決構造函數參數的匹配問題當構造函數中有多個同類型的參數時,Spring只允許你使用從0開始的index或者value標籤來解決這個問題。請看下面的例子:class="com.lizjason.spring.BillingService">

  最好用type屬性取代上面的做法: class="com.lizjason.spring.BillingService">value="lizjason"/>

  用index可以稍微減少冗餘,但是它更容易出錯且不如type屬性可讀性高。你應該僅在構造函數中有參數衝突時使用index。

  5.如可能,儘量複用bean定義

  Spring提供了一種類似於繼承的機制來降低配置信息的重複並使XML配置更加的簡單。一個子bean可以從它的父bean繼承配置信息,本質上這個父bean就像它的子bean的一個模板。這是一個在大型項目中必須使用的特性。所有你要做的就是把父bean的abstract屬性置爲true,並在子bean中加以引用。例如:

  

      class="com.lizjason.spring.AbstractService">value="lizjason"/>parent="abstractService"class="com.lizjason.spring.ShippingService">
  shippingService bean繼承了abstractService bean的屬性companyName的值lizjason。注意,如果你爲bean聲名一個class或工廠方法,這個bean將會默認爲abstract.

     6.儘量使用ApplicationContext裝配bean,而不是用import像Ant腳本中imports一樣,Spring的import 元素對於模塊化bean的裝配非常有用,例如:class="com.lizjason.spring.OrderService"/>

  然而,比起在XML中用imports預裝配這些bean,利用ApplicationContext來配置它們將更加靈活,也可以使XML配置更加的易於管理。你可以像下面這樣傳遞一個bean定義數組到ApplicationContext的構造函數中:

String[] serviceResources ={"orderServices.xml","billingServices.xml","shippingServices.xml"};

ApplicationContext orderServiceContext = newClassPathXmlApplicationContext(serviceResources);

  7.用id來標識bean你可以用id或名字作爲bean的標識。用id可讀性較差,但是它可以影響XML分析器使bean的reference有效。如果id由於XML IDREF約束而無法使用,你可以用name作爲bean的標識。XML IDREF約束是指id必須以字母開始(或者是在XML聲名了的一個標點符號),後面可以是字母,數字,連字符,下劃線,冒號或full stops(不知道怎麼翻譯好)。在實際應用中很少會遇到XML IDREF約束問題。

     8.在開發階段使用依賴檢查你可以爲bean的dependency-check屬性設置一個值來取代默認的none,比如說simple,objects或者all,這樣的話容器將替你做依賴有效性的檢查。當一個bean的所有屬性(或者某些屬性目錄)都被明確設置,或利用自動裝配時將會非常有用。class="com.lizjason.spring.OrderService"dependency-check="objects">value="lizjason"/> 在這個例子中,容器將確保這些屬性不是privitives或者保證collections是爲orderService bean設置的。爲所有的bean設置默認的依賴檢查是可能的,但這個特性由於有些bean的屬性不需要設置而很少使用。

  9.爲每個配置文件加一個描述註釋

  在XML配置文件中最好使用有描述性的id和name,而不是成堆的註釋。另外,加一個文件描述頭將會非常有用,這個描述可以概括文件中定義的bean。另一個選擇,你可以在description元素中加入描述信息。例如:

  This file defines billing servicerelated beans and it depends onbaseServices.xml,which providesservice bean templates......

  用description元素的一個好處就是工具可以很容易的把描述信息從這個元素中提取出來。

  10.和team members溝通變更

  當你修改java源碼後,要確保更改了配置文件中的相應部分並把這個情況告知你的team members。XML配置文件也是代碼,它們是程序的重要組成部分,但它們很難閱讀和維護。大多數時間裏,你需要同時看XML配置文件和java代碼才能知道是怎麼回事。

  11.setter注入和構造函數注入,優先使用前者

  Spring提供了三種注入方式:構造函數注入,setter注入和方法注入。一般我們使用前兩種。

  

      class="com.lizjason.spring.OrderService">class="com.lizjason.spring.BillingService">ref="billingDAO">
  在這個例子中,orderService bean用了構造函數注入,而BillingService bean用了setter注入。構造函數注入可以確保bean正確地構建,但是setter注入更加的靈活和易於控制,特別是當class有多個屬性並且它們中的一些是可選的情況是更是如此。12.不要濫用注入就像前面提到的,Spring的ApplicationContext可以替你創建java對象,但不是所有的java對象都應該通過注入創建。例如,對象就不應該通過ApplicationContext創建。Spring是一個優秀的框架,但是考慮到可讀性和可操控性,基於XML配置的配置會在定義很多bean的時候出現麻煩。過渡使用依賴注入將會使XML配置更加的複雜和冗長。切記,當使用高效的IDE時,例如Eclipse and IntelliJ,java代碼更加的易於閱讀,維護和管理比使XML文件。結論XML是Spring流行的配置格式。存在大量bean定義時,基於XML的配置會變得冗長而不易使用。Spring提供了豐富的配置選項。適當地使用這些選項可以使XML配置更加的清晰,但其它的一些選項,例如自動裝配,可能會降低可讀性和可維護性。參考本文中提到的這些技巧可能會幫助你創建乾淨而易讀的XML配置文件。

=============================================

http://www.cnblogs.com/lzhdim/archive/2008/12/25/1362481.html
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章