<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    張昊

    J-Hi(http://www.j-hi.net)

      BlogJava :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
      45 Posts :: 1 Stories :: 110 Comments :: 0 Trackbacks

    在軟件世界里組件這個概念真是千差萬別,每個系統(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)類似于插件一樣的可插拔,隨需織入。

    posted on 2011-03-07 01:03 張昊 閱讀(1338) 評論(1)  編輯  收藏

    Feedback

    # re: J-Hi對組件化的理解 2011-03-07 01:10 張昊
    笑蕭 0:40:45
    我看了下,組件化開發(fā) 挺好的,你把組件分為系統(tǒng)組件、業(yè)務(wù)組件、和技術(shù)組件,你的這些組件間的通信 有什么約束沒有?能保證你的組件的獨立性不能?
    張昊 0:41:34
    接口
    張昊 0:41:41
    通過配置
    張昊 0:42:00
    1、接口
    2、配置
    3、無縫集成
    張昊 0:44:10
    通過接口做約定
    通過配置文件,實現(xiàn)接口約定
    通過發(fā)布器與部署器,將業(yè)務(wù)組件無縫集成于業(yè)務(wù)系統(tǒng)中
      回復  更多評論
      


    只有注冊用戶登錄后才能發(fā)表評論。


    網(wǎng)站導航:
     
    主站蜘蛛池模板: 亚洲视频免费在线播放| 亚洲精品无码久久毛片| 亚洲欧洲日产国码二区首页| 无码国产精品一区二区免费模式| 国产精品亚洲аv无码播放| 成人一区二区免费视频| 亚洲人成人网站色www| 永久免费av无码网站yy| 亚洲成人激情在线| free哆啪啪免费永久| 亚洲日韩一区二区三区| 国产免费卡一卡三卡乱码| jyzzjyzz国产免费观看| 国产亚洲精品无码成人| 桃子视频在线观看高清免费视频| 亚洲高清在线mv| 午夜毛片不卡高清免费| 四虎影视永久在线精品免费| 亚洲午夜国产精品无码老牛影视| 国产精品免费大片| 亚洲五月综合网色九月色| 国产成人啪精品视频免费网| 最近更新免费中文字幕大全| 久久久亚洲AV波多野结衣| 毛片A级毛片免费播放| 皇色在线免费视频| 亚洲欧洲日产v特级毛片| 成人爱做日本视频免费| 男女一边摸一边做爽的免费视频| 久久青青草原亚洲av无码app | 色欲色欲天天天www亚洲伊| www.91亚洲| 91福利免费体验区观看区| 亚洲乱亚洲乱妇24p| 亚洲国产精品无码久久久不卡| 久久精品无码专区免费青青| 亚洲精品无码专区| 亚洲AV无码乱码在线观看富二代| 国产三级在线观看免费| 怡红院免费全部视频在线视频| 亚洲六月丁香六月婷婷色伊人|