在軟件世界里組件這個概念真是千差萬別,每個系統(tǒng)與工具軟件對組件都有各自不同的定義。尤其在Java世界里更是如此,小的從一個頁面元素一直到大的一個
業(yè)務(wù)功能系統(tǒng),在各自的領(lǐng)域都會給它們定義為組件。按照《計算機百科全書》給組件的定義:是軟件系統(tǒng)中具有相對獨立功能、接口由契約指定、和語境有明顯依
賴關(guān)系、可獨立部署、可組裝的軟件實體。由此定義我們來談一下J-Hi Java快速開發(fā)平臺對組件的理解與解決方案。
實際上說到底無非是對組件顆粒的劃分問題,在不同的條件與環(huán)境下組件的作用與功能會有很大差異,其次在定義組件時要保證功能的相對獨立并且可組裝可部署,
由此J-Hi將組件根據(jù)用途與范圍的不同劃分為如下四類組件類型:技術(shù)組件、實體組件、業(yè)務(wù)組件、系統(tǒng)組件,它們之間的關(guān)系是逐級遞進,互為基礎(chǔ)的。

在我們在深入探討之前,先來簡單的解釋一下上圖中各種組件類型之間的關(guān)系。比如一個OA系統(tǒng)我們就可以把這理解為一個系統(tǒng)組件,而多個系統(tǒng)組件(倉儲系
統(tǒng)、人力系統(tǒng)等)可以動態(tài)搭建更大的應用系統(tǒng)(ERP)。每個系統(tǒng)組件下會有多個業(yè)務(wù)組件,例如在OA系統(tǒng)下會有報銷單、會議管理等多個業(yè)務(wù)組件。因為大
部分業(yè)務(wù)組件之間一般都是松藕合的,所業(yè)務(wù)組件可以無縫的遷移到其它的系統(tǒng)組件中,即實現(xiàn)業(yè)務(wù)組件可復用性。而在一個業(yè)務(wù)組件下會有一個或多個實體組件夠
成,我們還以報銷單業(yè)務(wù)組件為例,在報銷單最少會有報銷單及報銷單明細兩個實體組件,一個實體您可以理解成與數(shù)據(jù)庫對應的一張表,實體之間可以繼承、一個
實體可以有多個子實體。但實體不僅僅是數(shù)據(jù)庫表,它包括從頁面到數(shù)據(jù)庫表之間的全部代碼實現(xiàn)同時包括CURD所有操作的功能單元。對于實體組件我們會在后
面詳細討論。最后是技術(shù)組件,在J-Hi中技術(shù)組件可以說是一個抽象的概念,一個技術(shù)組件就是一個技術(shù)功能單元,它可能是一套生成模版,一個框架的支持,
一套API(比如對短信、全文檢索的支持等)
實體組件:J-Hi將一個實體組件定義為一個集合單元,它不僅僅包括數(shù)據(jù)庫表還包括對該數(shù)據(jù)庫表的基礎(chǔ)操作
(增、刪、查、改);包括前端的展示面頁;包括該實體的權(quán)限、菜單、配置信息;還包括它與其它實體的交互操作。當然一個實體組件顆粒度還是太小,還不能完
整的描述一個業(yè)務(wù)功能。但實體組件相對來說有一定的獨立性,可以集成一個集合單元,J-Hi就是以實體組件為基礎(chǔ)實現(xiàn)更大粒度的集成,從而實現(xiàn)對一個完整
業(yè)務(wù)的描述。

業(yè)務(wù)組件:實際上一個業(yè)務(wù)組件J-Hi將它對應于一個服務(wù),服務(wù)可以認為是一個業(yè)務(wù)功能模塊,用以描述完整的
業(yè)務(wù)模式,具體相對的業(yè)務(wù)獨立性。在服務(wù)內(nèi)代碼間是高聚集的,因為一個服務(wù)就是一套完整的業(yè)務(wù),在設(shè)計服務(wù)時應盡最大限度的降低服務(wù)與服務(wù)之間的藕合度。
因為在這個樣一個理論基礎(chǔ)上去設(shè)計,就可以實現(xiàn)業(yè)務(wù)組件無縫的在各系統(tǒng)之間的可移植性。因為組件的定義還要可以獨立的組裝與部署,因此我們開發(fā)平臺的附屬
性產(chǎn)品——Hi平臺產(chǎn)品集成工具,它主要是由發(fā)布器與部署器組成,以更方便的實現(xiàn)業(yè)務(wù)組件的遷移。


開發(fā)發(fā)布器與部署器的目的就是通過可視化的方式,實現(xiàn)跨數(shù)據(jù)庫數(shù)據(jù)與跨應用系統(tǒng)的業(yè)務(wù)組件遷移。可以將業(yè)務(wù)組件看作一個獨立的業(yè)務(wù)單元,可以無縫的集成于
任何以J-Hi平臺開發(fā)的項目中去。從而真正達到隨需組合,動態(tài)搭建實際的業(yè)務(wù)系統(tǒng),真正的實現(xiàn)業(yè)務(wù)組件的復用,降低不必要的重復開發(fā)。
系統(tǒng)組件:從業(yè)務(wù)功能上來看系統(tǒng)組件不過是多個業(yè)務(wù)組件的拼接,更大一級的業(yè)務(wù)封裝。理論上系統(tǒng)組件與系統(tǒng)組
件之間應滿足絕對的隔離性,即使是有通信,應該也是通過第三方來進行數(shù)據(jù)交互(常用的解決方式有兩種一種是中間數(shù)據(jù)庫;第二種是webservice)。
但如果是基于平臺開發(fā),這種無謂的工作量可以降低很少,甚至可以不需要第三方的交互技術(shù)。只要保證兩個系統(tǒng)間的通信接口就要以輕松實現(xiàn)。系統(tǒng)組件的遷移也
可以通過發(fā)布器與部署器來實現(xiàn)。
技術(shù)組件:從技術(shù)角度來看,J-Hi與其它的技術(shù)組件差別不大。無非是基于平臺再開發(fā)一些技術(shù)組件,比如對
SpringMVC、SpringJDBC、DB2數(shù)據(jù)庫等的支持,頁面端也會再集成象DWZ或simpleframework,我們也會再提供更多的頁
面端的生成模版,以此類推,平臺的技術(shù)組件會在技術(shù)的不同層面進行擴展。但與其它的技術(shù)組件不同之處在于,實現(xiàn)類似于插件一樣的可插拔,隨需織入。