Spring的打包方式

獲取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依賴關係,合者納之,餘者棄之。

 
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章