程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> 理解Spring的打包方式

理解Spring的打包方式

編輯:關於JAVA

獲取Spring發布包之後,你或許會驚訝的發現:Spring開發小組並沒有用單個JAR文件來包含所有代碼,而是選擇建立包含有完整發布的單個JAR和8個獨立JAR文件來包含對應的Spring組件。未來版本的組件JAR文件數量很可能會有所增加,可令你更加自如的選擇自己的代碼要包含的特性。

完整發布包

所有發布版本都提供spring.jar文件,它差不多包含Spring framework類的完整發布包。之所以說“差不多”是因為它實際上並未包含任何mock類,這些類隨Spring一起發布,作為輔助測試之用。這可是Spring開發小組的明智決定,因為發布應用時你幾乎從不需要同時分發mock類;你只是在開發環境下用它們來輔助測試過程。除此之外,spring.jar文件包含Spring main源碼樹裡所有其它類。

組件發布包

除了spring.jar文件,Spring還包括前面提及的另外8個JAR文件;其中一個包含mock類,另外七個包含Spring framework的獨立組件。表2-1列出了這些JAR文件,並伴有對應組件的說明。 表2-1:Spring組件發布包 JAR文件 說 明 spring-aop.jar 這個JAR文件包含在應用中使用Spring的AOP特性時所需的所有類。如果打算使用其它基於AOP的Spring特性,比如聲明型事務管理(declarative transaction management),也需要在應用裡包含這個JAR文件。 spring-context.jar 這個包裡的類為Spring核心提供了大量擴展。你可以找到使用Spring ApplicationContext特性(第5章有介紹)時所需的全部類,以及支持EJB、JNDI和郵件集成所需的類。此外這個包還囊括Spring遠程調用(remoting)類,用來與模板(templating)引擎如Velocity和FreeMarker集成的類,以及驗證基類(base validation class)。值得注意的是,實際上許多類被包含在這個包裡並不是太恰當,比如遠程調用和EJB支持之類的特性,打包成單獨的JAR文件更為恰當。 spring-core.jar 所有應用都要用到這個JAR文件,它包含訪問配置文件、創建和管理bean以及進行DI操作相關的所有類。如果你的應用只需基本的DI支持,該JAR文件足以滿足需要。此外該JAR文件還包含一組極為有用的工具類,Spring代碼庫大量使用了這些類,也可以用在自己的應用中。 spring-dao.jar 這個JAR文件囊括Spring DAO支持相關的所有基類,還包含用JDBC和Spring的事務抽象層(transaction abstraction layer)進行數據訪問的所有類。為了使用聲明型事務支持,還需在自己的應用裡包含spring-aop.jar。 spring-mock.jar 前面已經提及,Spring提供了一整套mock類來輔助應用的測試。Spring測試套件使用了其中大量mock類,因此它們已久經考驗,可令你的應用測試更為簡單。至於模擬(mock)HttpServletRequest 和HttpServletResponse類在web應用單元測試中的巨大用處,更是毋須贅言。 spring-orm.jar 這個JAR文件對Spring的標准DAO特性集進行了擴展,使其支持Hibernate、iBATIS和JDO。這個JAR文件裡大量的類都依賴spring-dao.jar裡的類,毫無疑問你需要同時包含後者。將來每個ORM工具或許會單獨打包,這樣一來,使用iBATIS時你的應用就無需再包含Hibernate和JDO相關的類。 spring-web.jar 這個JAR文件包含web應用使用Spring時所需的核心類,包括自動載入ApplicationContext特性的類、Struts集成類、文件上傳的支持類和大量輔助類,用來執行重復性的任務如解析查詢(query)字符串裡的int值。 spring-webmvc.jar 這個JAR文件囊括Spring MVC框架相關的所有類。如果你的應用使用了獨立的MVC框架,則無需這個JAR文件裡的任何類。第18章會對Spring MVC作更詳細的介紹。

如何選擇發布包

決定選用哪些發布包其實相當簡單。如果你正在構建web應用並將全程使用Spring,那麼最好使用spring.jar文件,以免陷入忙於維護不同文件之泥沼。同樣的,如果你的應用僅僅用到簡單的DI容器,那麼只需spring-core.jar即可搞定。如果你對發布的大小要求很高,那麼理應精挑細選,只取用包含自己所需特性的JAR文件。

注意上述組件發布包的粒度實際上並不是那麼小;不過顯然你至少可以避免包含自己的應用不需要的全部類(譯注:即還是會包含一些不需要的類)。或許你可以設法令整個應用稍稍變小,不過節省空間的重頭戲在於如何准確找出自己所需的Spring依賴關系,合者納之,余者棄之。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved