----- Original Message -----
From: "張昊" <
hao.zhang.hi@gmail.com >
To: <
jinhe@51cto.com >
Sent: 2011-03-16 17:15:50 +0800
Subject: J-Hi張昊對您的回復(fù)
標(biāo)題 |
發(fā)件人 |
EMAIL |
時(shí)間 |
留言方式 |
|
技術(shù)咨詢 |
金賀 |
jinhe@51cto.com |
03-14 16:10 |
私人留言 |
Delete |
您好,張昊先生,我是51CTO的金賀,有幾個(gè)問題想請教您一下,請問您方便嗎?
我是張昊,請教可真不敢當(dāng)。如果有什么我能效勞的,您直管說。盼回復(fù) |
在 2011年3月16日 下午5:45,金賀
<jinhe@51cto.com>寫道:
非常感謝您,我是看到您的帖子對您很好奇,主要有下面幾個(gè)問題想咨詢您一下。
1. 您是什么時(shí)候接觸到J-HI這項(xiàng)技術(shù)的,基于什么樣的目的呢?
我是J-Hi項(xiàng)目的發(fā)啟者, 從2005年末時(shí)我就開如做這個(gè)項(xiàng)目了。當(dāng)時(shí)它還只是大家為了探索如何使程序開發(fā)更好、更快速、易于管理而又不影響開發(fā)人員的編程習(xí)慣的一個(gè)構(gòu)想,當(dāng)初它還只是個(gè)底層框架或開發(fā)工具,核心團(tuán)隊(duì)成員就是用這個(gè)小小的底層框架做了很多項(xiàng)目,從未想過會(huì)將它開源出來(因?yàn)槲覀冇X得做
得還不夠好,擔(dān)心開源后會(huì)被同行笑話)。后來隨著所接項(xiàng)目的逐漸增多,J-Hi所涉足的行業(yè)領(lǐng)域也不斷廣闊,因此我們也不得不適應(yīng)需求的變化不斷的為它加
入新的功能,慢慢的它變得越來越強(qiáng)壯。突然有一天有人提議我們將它開源吧,大家這才為平臺(tái)的開源做準(zhǔn)備。從我們今年1月14日開始推廣以來,有很多的愛好者加到其中,這樣我和我的團(tuán)隊(duì)感到很欣慰,覺得我們努力得到了大家的認(rèn)可!
2. 這項(xiàng)技術(shù)有什么優(yōu)點(diǎn)?是否已經(jīng)在實(shí)踐中證實(shí)呢?
快速的按需動(dòng)態(tài)搭建
目前平臺(tái)支持的框架有:webwork、struts2、spring、hibernate、ibatis2、ibatis3,對于這些框架您可以通過可視化(J-HI Studio,eclipse插件)的方式隨意組合,通過工程創(chuàng)建向?qū)В?wbr>自動(dòng)化的按照你所選擇的框架快速的動(dòng)態(tài)搭建起開發(fā)工程。我們之所以將J-Hi做成多框架動(dòng)態(tài)搭建,主要是考慮到不同企業(yè)的開發(fā)團(tuán)隊(duì)對技術(shù)的傾向性會(huì)有很大差別,比如對于ORM有的人就喜歡hibernate,而有的人就覺得hibernate太強(qiáng)硬,喜歡用半自動(dòng)化的ibatis。J-Hi基于這個(gè)目的為開發(fā)者提供了更多的可選擇性。在此要注意對于平臺(tái)多框架的集成并不象一般意思上的集成(即幾個(gè)框架拼接在一起就可以象appfuse一樣),因?yàn)槠脚_(tái)的集成還要包括很多通用業(yè)務(wù)并且與數(shù)據(jù)庫表是有關(guān)系的(一般搭建多框架是沒有業(yè)務(wù)的所有的東西都要由你親自去開發(fā),而平臺(tái)會(huì)有很多的業(yè)務(wù)已經(jīng)預(yù)留在平臺(tái)中)。舉個(gè)例子:比如安全管理,這是平臺(tái)的一個(gè)通用業(yè)務(wù)包括角色、權(quán)限等。在切換到不同的框架比如struts或webwork;hibernate或ibatis時(shí),平臺(tái)的底層要自動(dòng)的適應(yīng)這種變化,這是有一定的創(chuàng)新點(diǎn)的J。當(dāng)然我們以后還會(huì)集成更多、更優(yōu)秀的框架在平臺(tái)之中,比如SpringMVC,SpringJDBC等等,在數(shù)據(jù)庫端我們也會(huì)再多支持一些數(shù)據(jù)庫,當(dāng)然集成數(shù)據(jù)庫也不是傳統(tǒng)意義上的只是一個(gè)數(shù)據(jù)庫連接,而是針對不同的數(shù)據(jù)庫差異會(huì)做不同的方言,不同的數(shù)據(jù)庫腳本還要有相應(yīng)的生成模板等等。
因此你會(huì)發(fā)現(xiàn)快速按需動(dòng)態(tài)搭建,并不是傳統(tǒng)意義上的多框架集成那么簡單,而是對應(yīng)每一種框架(數(shù)據(jù)庫)平臺(tái)都會(huì)提供一套完整的解決方案。總之多框架集成對于J-Hi來說,是牽一發(fā)而動(dòng)全身的事情,變動(dòng)一個(gè)框架,包括每一個(gè)頁面,每一個(gè)java類,每一個(gè)配置文件都要隨之而動(dòng)態(tài)的變化。因此它是系統(tǒng)級(jí)的工程而非簡單的多個(gè)框架拼接。
完整而系統(tǒng)的生成方案
代碼生成或生成器這實(shí)際上在十年前就已經(jīng)有的東西,無論是實(shí)現(xiàn)原理還是具體的工具都不是新鮮事物。J-Hi之所以將代碼生成也算作自己的特色,是因?yàn)樗耐暾耘c系統(tǒng)性。從完整性來看,J-Hi的生成是一套含蓋從數(shù)據(jù)庫底層一直到頁面端全部的解決方案,包括數(shù)據(jù)庫表;權(quán)限、菜單、多語言等相關(guān)基礎(chǔ)數(shù)據(jù);java類文件;JSP、js文件;相關(guān)配置文件等等,因此保證了生成即可運(yùn)行,從單元體上來看生成文件是完整的,是可獨(dú)立運(yùn)行的。從系統(tǒng)性來看,生成的文件是隨著你選擇的框架不同而不同的,生成的基礎(chǔ)是隨著框架與數(shù)據(jù)庫的差異而隨需變化,系統(tǒng)的解決了生成器的僵硬性,從而靈活的適應(yīng)開發(fā)環(huán)境。因此J-Hi的生成方案是系統(tǒng)的,是適應(yīng)不同框架與數(shù)據(jù)庫的生成方案的。
平臺(tái)到底生成了些什么?
組件化
J-Hi把組件劃分為四類,技術(shù)組件、實(shí)體組件、業(yè)務(wù)組件與系統(tǒng)組件,具體內(nèi)容請參見平臺(tái)組件化
J-Hi的理論基礎(chǔ)請參見:http://www.blogjava.net/hao-zhang-hi/archive/2011/02/27/345277.html
J-Hi就是從實(shí)際的項(xiàng)目開發(fā)過程中誕生與完善起來的,它把主要把關(guān)注放在如何解決快速開發(fā)與降低成的問題上。如果從一個(gè)項(xiàng)目的整個(gè)生命期來看,實(shí)際上開發(fā)只占了總項(xiàng)目的成本的一小部分,然后就是這一小部分還是有大量的成本損耗。比如在管理上,人員變動(dòng)對開發(fā)的影響;在技術(shù)偏向性上,增加了開發(fā)人員的學(xué)習(xí)曲線從而使成本提高;在功能的復(fù)用性上,在項(xiàng)目開發(fā)過程會(huì)發(fā)現(xiàn)每次都會(huì)做一些稍有差異但實(shí)際是功能重疊的東西;在具體coding過程中,會(huì)寫一樣模式化的但又不得不寫的東西(如POJO等)。J-Hi就是為了解決上述問題而產(chǎn)生的。
當(dāng)然J-Hi還有弱小,以后我們還不斷的完善,使它越來越強(qiáng)大。
3. 哪些領(lǐng)域能運(yùn)用這項(xiàng)技術(shù),您能有一些好的建議么?
4. 對于剛剛接觸J-HI這項(xiàng)技術(shù)的人群,有什么好的學(xué)習(xí)建議
平臺(tái)類的產(chǎn)品對于使用它的開發(fā)者來說都有同樣的特點(diǎn):使聰明人更加聰明,使懶惰的人更加懶惰(從而失去了思想)。我希望所有接觸J-Hi的愛好者都能成為前者,而不是后者。因?yàn)樵贘-Hi的設(shè)計(jì)之初間中的一個(gè)理念就是,讓它成為希望了解主流框架人一個(gè)學(xué)習(xí)工具。從這一點(diǎn)來看,J-Hi也跟Appfuse很象,但要比Appfuse更完善,更全面,更貼進(jìn)去業(yè)務(wù)。
另:我可以把我的回復(fù)發(fā)到我的博客上嗎?
在 11-3-17,金賀<
jinhe@51cto.com> 寫道:
> 非常感謝您百忙之中回復(fù)我,您的這些回復(fù)使我茅塞頓開呀,看來我也得接觸一下這個(gè)技術(shù)了,回復(fù)您可以隨便發(fā)送的。
>
> 祝您工作順利,身體健康。以后我有問題還得向您請教,希望您不會(huì)拒絕吧,哈哈