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

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

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

    kapok

    垃圾桶,嘿嘿,我藏的這么深你們還能找到啊,真牛!

      BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
      455 隨筆 :: 0 文章 :: 76 評(píng)論 :: 0 Trackbacks
    使用AppFuse進(jìn)行開發(fā)的總結(jié)
    http://rabbit8.blogchina.com/blog/article_144619.796348.html


    AppFuse是一個(gè)集成了當(dāng)前最流行的Web應(yīng)用框架的一個(gè)更高層次的Web開發(fā)框架,也可以說是一個(gè)Web開發(fā)基礎(chǔ)平臺(tái),它與之所集成的各種框架相比,它提供了一部分所有Web系統(tǒng)開發(fā)過程中都需要開發(fā)的一些功能,如登陸、用戶密碼加密,用戶管理、更具不同的用戶可以展現(xiàn)不同的菜單,可以自動(dòng)生成40-60%左右的代碼,自帶了默認(rèn)的一些在CSS中設(shè)定的樣式,使用這些樣式能很快的改變整個(gè)系統(tǒng)的外觀,還有自動(dòng)化測(cè)試的功能。

          它最大的價(jià)值就是為我們提供了一個(gè)Web開發(fā)的新的方式和思路,盡管這些技術(shù)在國外都已進(jìn)很流行了,但在國內(nèi)能夠?qū)?FONT size=+0>Hibernate、StrutsSpringDBUnitAntLog4JStruts MenuXdocletSiteMeshVelocityJUnitJSTLWebWork這些技術(shù)集成到一個(gè)框架中的還不多見,所以即使不使用它的全部功能,它也給我們提供了一個(gè)很好的借鑒、學(xué)習(xí)的機(jī)會(huì)。

          AppFuse的作者 matt raible是當(dāng)今開源世界一個(gè)比較活躍的開發(fā)者,它是AppFuse、Struts Menu的作者,也是XDoclet、DisplayTag等一些著名開源項(xiàng)目的積極參與者,《Hibernate In Action》的作者就在感謝的名單里面提到他,XDoclet的下載版本中所帶的Hibernate標(biāo)簽部分的例子就是他寫的,他還是2004年Apache技術(shù)年會(huì)的主講人之一。(這些都是我這2個(gè)多月來搜集到的,呵呵)

     

           通過關(guān)注AppFuse,我們可以看到目前國外的主流開發(fā)都使用了哪些技術(shù),開發(fā)方式是什么樣的,可能達(dá)到什么樣的結(jié)果,而在以前,是很少能夠看到這樣完整的例子的。

           AppFuse的另一個(gè)啟示是:我們可以依靠開源軟件的功能降低開發(fā)成本,而且可以閱讀開源軟件的代碼提高所在團(tuán)隊(duì)的整體實(shí)力。

          

           但是通過2個(gè)月的實(shí)際學(xué)習(xí)和使用,我也遇到一系列的問題,因?yàn)?FONT size=+0>AppFuse是將其他的一些類庫或者框架集成在一起的,集成的技術(shù)眾多,而且有一些技術(shù)在國內(nèi)甚至很少有人知道,資料也比較少,所以雖然作者經(jīng)過了一些測(cè)試,但都是基于英文編碼的,而對(duì)于中文編碼來說,還潛在的存在著一些問題,雖然不是AppFuse的問題,但卻降低了開發(fā)速度,下面是我在開發(fā)過程中遇到過的問題,有些解決了,有些還沒有解決:

    一.Struts

    1.  AppFuse中默認(rèn)的MVC框架是Struts,而且使用的是LookupDispatchAction,并且使用的是按鈕(button),在XP下用IE瀏覽效果還可以,但如果在2000或者98下,就使外觀很難看,而且當(dāng)時(shí)我還遇到一個(gè)問題:如果按鈕顯示中文,則在DisplayTag中翻頁失靈,而且報(bào)錯(cuò),后來我把BaseAction的相關(guān)方法改變了,才可以使用,因?yàn)閲鴥?nèi)的客戶都比較重視界面,所以后來我將那些按鈕都改成圖片了,當(dāng)然也要添加一些方法了,有點(diǎn)麻煩!

    2.  Struts中的標(biāo)簽如今推薦使用的只有html部分的標(biāo)簽了,其他的標(biāo)簽或者可以使用JSTL替代,或者已經(jīng)不推薦使用了,而且AppFuse中推薦使用JSTL,而JSTLstruts的標(biāo)簽的聯(lián)合使用時(shí),需要的不是標(biāo)簽<html:標(biāo)簽>,而是標(biāo)簽<html-el:標(biāo)簽>,這個(gè)問題曾經(jīng)困擾了我整整2天。

    3.  StrutsValidation的校驗(yàn)規(guī)則并不完善,比如如果使用客戶端的javascript校驗(yàn),則在郵箱中輸入漢字根本校驗(yàn)不出來,到了服務(wù)器端報(bào)錯(cuò)。

    4.  最嚴(yán)重的問題是AppFuse生成的Strutsvalidation.xml文件中有許多多余的".",如果你去掉了,常常在執(zhí)行antdeploy任務(wù)時(shí)又恢復(fù)原樣。這樣是提交表單的時(shí)候經(jīng)常會(huì)報(bào)javascript的腳本錯(cuò)誤或者缺少對(duì)象或者缺少value,所以我會(huì)手工的修改這個(gè)文件,然后把修改后的文件備份,當(dāng)重新生成有錯(cuò)誤的文件時(shí),我會(huì)用備份的沒有錯(cuò)誤的文件去覆蓋。

    5.  Strutsvalidatioin對(duì)于使用同一個(gè)FormBeanAction的校驗(yàn)方式比較復(fù)雜。(待解決)。

    二.Hibernate

    1.  Hibernate是現(xiàn)在受到越來越多的人推崇的一個(gè)ORM工具(框架、類庫),它將我們從繁瑣的使用JDBC的開發(fā)過程中解放出來,但同時(shí)也帶來了新的問題,如學(xué)習(xí)曲線,執(zhí)行效率,數(shù)據(jù)庫設(shè)計(jì)優(yōu)化,還有最重要的靈活性。Hibernate不是一個(gè)很容易上手的東西,要完全駕馭它還需要讀很多資料,但好的資料卻很少。

    2.  使用Xdoclet可以很方便的生成Hibernate中的持久類的配置文件(*.hbm.xml,但對(duì)一些特殊的映射卻無能為力,如使用序列的id生成規(guī)則,序列的名字沒有地方寫,所以也只好先利用它生成主要的內(nèi)容,然后手工修改。

    3.  同樣還是id的生成策略問題,如果使用序列、hilo等需要一些數(shù)據(jù)庫機(jī)制支持的策略時(shí),schemaExport并不能自動(dòng)生成序列或者保存當(dāng)前id的表,這項(xiàng)工作仍然要手工解決。

    4.  Hibernate中提供了幾種關(guān)聯(lián),一對(duì)一、一對(duì)多、多對(duì)多,但對(duì)于怎樣調(diào)整效率卻沒有一個(gè)很明確的提示,還要根據(jù)情況判定,這就帶來和一些彈性的設(shè)計(jì)。

    5.  Hibernate中可以選擇的操作數(shù)據(jù)庫的方式有3種,其中HQL功能最強(qiáng)大,但有些功能使用標(biāo)準(zhǔn)查詢可能會(huì)更方便,但會(huì)有一些限制,所以雖然它很靈活,但易用性不如JDBC好。

    三.Spring

           AppFuse的過程中,Spring完全隱藏在幕后,除了一些配置外,幾乎感覺不到它的存在,所以我在使用它的過程中并沒有遇到什么麻煩,這里只是簡(jiǎn)單的介紹一下它在AppFuse中起到的作用。

    1.  SpringAppFuse中起到的主要作用是對(duì)HibernateSession和事務(wù)的管理,利用Spring封裝的Hibernate模板類,我們大大地減少了實(shí)現(xiàn)DAO的代碼行數(shù)。

    2.  Spring還起到了連接映射文件和類之間的關(guān)聯(lián),及接口和實(shí)現(xiàn)類之間的關(guān)聯(lián),這些都依賴于SpringIoC的機(jī)制的實(shí)現(xiàn)。

    3.  對(duì)于字符進(jìn)行編碼和解碼部分用到了Spring自帶的Filter,只需要在配置文件中配置就好了。

     

    四.SiteMesh

    SiteMesh是一個(gè)基于Decorator模式的技術(shù),它可以修飾返回的網(wǎng)頁文件,它的工作方式受到越來越多的人的推崇,這點(diǎn)從Manning出版的一些技術(shù)書籍中可以看出來。

    我在使用SiteMesh的過程中并不順利,我參考了《Java Open Source Programming》,這本書中說SiteMesh在默認(rèn)的情況下不對(duì)下載文件進(jìn)行裝飾,但我在下載文件時(shí)發(fā)現(xiàn),我的文件內(nèi)容被丟棄了,取而代之的是SiteMesh的模板的內(nèi)容,后來我通過修改SiteMesh的配置文件解決了這個(gè)問題,但感覺還有一些不太清楚的地方需要學(xué)習(xí)。

     

    五.DisplayTag

           DisplayTag是一個(gè)優(yōu)秀的顯示內(nèi)容的標(biāo)簽,從SourceForge的訪問量來看,它是很活躍的項(xiàng)目,僅次于AntHibernateXdoclet等幾個(gè)著名的項(xiàng)目,我總結(jié),它的主要功能有4項(xiàng):顯示、分頁、排序、將顯示的數(shù)據(jù)寫入指定類型的文件中,然后下載。

    1.  據(jù)我使用的情況看,我只使用了分頁和顯示的功能,因?yàn)楫?dāng)時(shí)我沒有很好的解決中文編碼的問題,所以排序會(huì)有問題,直到昨天,我在朋友的幫助下解決了這個(gè)問題,至此我可以放心使用的功能又增加了排序(我昨天簡(jiǎn)單的測(cè)試了一下是可以的)

     

    2.  但對(duì)于將顯示的內(nèi)容生成到一個(gè)指定格式的文件中的功能卻有著很多缺陷,如:

    (1)       生成的文件中只有顯示的數(shù)據(jù),那些沒有顯示在界面上的的數(shù)據(jù),則不會(huì)被寫到文件中。

    (2)       如果修改了DisplayTag的顯示的內(nèi)容,比如添加一列,在這列中的內(nèi)容不是字符,而是HTML的標(biāo)簽,則生成的文件只有這些HTML標(biāo)簽,而沒有數(shù)據(jù)。

    (3)       即使DisplayTag中沒有我們定制的HTML腳本,生成的文件偶爾也有問題,比如:它會(huì)把"007"生成為"7",把字符串自動(dòng)的轉(zhuǎn)換為整型值。有時(shí)候還生成空白內(nèi)容的文件。

    (4)       DisplayTag生成的Excel文件兼容性不好,有時(shí)在Excel2003中不能正常打開,或者在XP下打開報(bào)錯(cuò)。

          后來,我看了作者寫的《Spring Live》,書中說如果想實(shí)現(xiàn)穩(wěn)定的Excel,推薦使用POI,于是我使用POI生成Excel,穩(wěn)定性和兼容性都不錯(cuò)。

    六.DBUnit

           DBUnit是一個(gè)可以被Ant集成的向數(shù)據(jù)庫中添加數(shù)據(jù)和備份數(shù)據(jù)的一個(gè)類庫,配置很方便,因?yàn)?FONT size=+0>AppFuse已經(jīng)集成好了,所以使用也很容易。

           但是如果你使用EditPlus之類的工具手工修改了AppFuse生成的內(nèi)容,則執(zhí)行Antsetupsetup-db或者deploy的任務(wù)時(shí),常常報(bào)錯(cuò),說無效的格式,這是因?yàn)檫@個(gè)被手工修改的文件再次被AppFuse執(zhí)行后,它的第一行的文件聲明的前幾個(gè)字母是無效的,是因?yàn)楸镜氐淖址幋a的原因而引起了亂碼,如果把這幾個(gè)無效的字母去掉,問題就解決了。

     

    七.Struts Menu

           Struts Menu也是AppFuse的作者開發(fā)的一個(gè)開源軟件,它可以根據(jù)配置文件讀取當(dāng)前用戶可以使用的功能菜單,這個(gè)功能是我一直以來都想要的,我也找到了一些代碼,但實(shí)現(xiàn)的都不如這個(gè)完善,沒什么好說的,使用簡(jiǎn)單,配置容易,很好的解決了我的問題。

           問題是我只使用了AppFuse提供的2個(gè)角色,對(duì)于多個(gè)角色的實(shí)驗(yàn)我還沒有做。

     

    八.XDoclet

           AppFuse中,使用Xdoclet生成了幾乎一切的配置文件:Struts-config.xmlweb.xmlvalidation.xml*.hbm.xml等文件,如果使用AppGen的話,還會(huì)生成更多的文件,這一切都是使用Xdoclet實(shí)現(xiàn)的。

           問題是我在Struts部分提到的,生成的Validation.xml文件中會(huì)多生成一個(gè)".",另外在生成資源文件時(shí)也會(huì)多生成一個(gè)".",目前我沒有很好的閱讀這段代碼,不知道是不是Xdoclet的問題。

     

    九.Ant

           Ant并沒有什么問題,但在執(zhí)行作者寫的Ant任務(wù)的時(shí)候,有一些任務(wù)不能正常執(zhí)行,比如,運(yùn)行模擬對(duì)象測(cè)試的任務(wù),作者也在1.7版本的修復(fù)列表中提到以前版本有些ant任務(wù)不能執(zhí)行,在1.7中修改了一些ant任務(wù),使他們能夠正常的執(zhí)行了。

           實(shí)際上,我們?nèi)绻褂?FONT size=+0>AppGen進(jìn)行開發(fā)的話,使用的任務(wù)一般不超過8個(gè)。

     

    十.JSTL

           JSTL是個(gè)好東西,我常用的有部分的標(biāo)簽,但是如果使用JSTL進(jìn)行邏輯判斷,我并沒有感覺比使用JSP的代碼塊優(yōu)雅多少。另外,熟悉JSTL也需要一段時(shí)間,我就經(jīng)歷了面對(duì)著JSP頁面不知道該怎么寫JSTL語法的困境。當(dāng)然,AppFuse中使用的基本都是JSTL,包括向DisplayTag傳遞顯示的數(shù)據(jù),使用的都是JSTL語法,這方面的資料挺多,我參考的是電子工業(yè)出版社出的《JSP2.0技術(shù)》,說的很詳細(xì)。

     

    十一.Tomcat

           你也許會(huì)說:"Tomcat就不用說了吧?",是的,Tomcat一般都會(huì)使用,但是―――――――――――――Tomcat5Tomcat4.X對(duì)于中文編碼使用了不同的機(jī)制,這個(gè)問題困擾了我好久,我解決了頁面上寫入漢字顯示亂碼的問題,我也曾經(jīng)以為DisplayTag對(duì)漢字不能排序,也不能正常分頁是因?yàn)?FONT size=+0>DisplayTag的開發(fā)者都是老外,是因?yàn)樗麄儧]有考慮中文的關(guān)系的原因。

          直到昨天,我才知道這一切都是因?yàn)?FONT size=+0>Tomcat5對(duì)漢字編碼的實(shí)現(xiàn)的方式和Tomcat4不一樣的原因,如果感興趣,可以看看這個(gè)帖子:http://www.javaworld.com.tw/jute/post/view?bid=9&id=44042&sty=1&tpg=1&age=0

          再次感謝倦兔!:D

     

    十二.JavaScript

           JavaScript簡(jiǎn)單易學(xué),但想運(yùn)用自如就不太容易了。AppFuse中嵌入了幾個(gè)js文件,里面包含了許多函數(shù),值得我們好好的研究一下,比如,如果有一個(gè)必填字段沒有填寫,AppFuse會(huì)自動(dòng)的聚焦在那個(gè)input上,類似的小技巧有很多,你可以自己去翻看。

           AppFuse自帶的JavaScript腳本有一個(gè)Bug,就是當(dāng)DisplatyTag中沒有可以顯示的數(shù)據(jù)時(shí),你用鼠標(biāo)單擊,它會(huì)報(bào)JavaScript錯(cuò)誤,你仔細(xì)研究一下function highlightTableRows(tableId) 就知道了:我的解決辦法是在location.href = link.getAttribute("href");前面添加一行判斷:if (link != null)。
     

    十三.資源文件國際化

           對(duì)于StrutsDisplayTag都涉及到資源文件國際化AppFuse1.6.1很好的解決了Struts資源映射文件國際化的問題,你只需要在對(duì)應(yīng)本國語言的資源文件中寫入漢字,Ant中有一項(xiàng)執(zhí)行native2ascii的任務(wù),AppFuse自動(dòng)的為你進(jìn)行了資源文件的編碼轉(zhuǎn)換,而對(duì)于DisplayTag的資源文件問題,還要自己執(zhí)行native2ascii命令,為了避免每次都輸入一串命令,我用Delphi寫了個(gè)小工具,可視化的選擇資源文件,點(diǎn)擊按鈕自動(dòng)執(zhí)行該命令,底層依賴于JDK

     
     

    經(jīng)過2個(gè)多月的學(xué)習(xí),我感覺這個(gè)框架非常不錯(cuò),它為我以后的項(xiàng)目開發(fā)指出了一個(gè)新的方向,但如果想很熟練的使用這個(gè)框架進(jìn)行開發(fā),至少要對(duì)以下幾種技術(shù)比較熟練:Struts(或者WebWorkSpring及其他的已經(jīng)整合進(jìn)來的MVC框架)Hibernate(或者ibatis)、JSTL,當(dāng)然其他的技術(shù)至少也要知道一點(diǎn),否則遇到問題都不知道出在哪里。

     
     

           目前我還沒有解決的問題有:

    1.  如何在翻頁的時(shí)候才讀取下面的數(shù)據(jù)?

    2.  怎樣對(duì)使用同一個(gè)FormBean的多個(gè)Form進(jìn)行客戶端校驗(yàn)?

    3.  怎樣優(yōu)化Hibernate的效率?《Hibernate In Action》中提供了多種策略,有些時(shí)候應(yīng)該使用lazy,有些時(shí)候應(yīng)該使用outer-join

    4.  在什么時(shí)機(jī)生成導(dǎo)出文件?目前我是在查詢的Action中同時(shí)生成了導(dǎo)出文件,否則,到了下一頁,我就不知道查詢條件了,當(dāng)然,如果把拼裝后的HQL存儲(chǔ)在Session或者Hidden中也可以解決這個(gè)問題,但是這樣就破壞了DAO的封裝,要把DAO封裝后的HQL發(fā)送給Action,然后發(fā)送的到Web界面層,所以目前我還在猶豫生成導(dǎo)出文件的時(shí)機(jī)選擇在哪里?

    5.  什么時(shí)候應(yīng)該自己獲取數(shù)據(jù)庫連接,執(zhí)行native SQL?具體需要注意些什么?

    6.  SiteMesh的模板優(yōu)化?

    7.  DisplayTag的底層實(shí)現(xiàn)?

     
     

    每個(gè)問題都比較棘手,要一個(gè)一個(gè)解決!   

     

           這個(gè)框架的優(yōu)點(diǎn)是:如果熟悉了開發(fā)流程,可以大幅度的提高開發(fā)速度,如果業(yè)務(wù)不是很復(fù)雜,使用AppGen可以生成60%左右的代碼,而且程序可維護(hù)性好,因?yàn)樽髡呤褂昧硕鄠€(gè)設(shè)計(jì)模式對(duì)各個(gè)層面進(jìn)行了封裝,所以不同的模塊代碼風(fēng)格出奇的一致,有利于開發(fā)人員快速上手,有利于接收其他開發(fā)人員遺留的代碼。

     

    兔八哥





    native2ascii在Ant中有任務(wù),可以寫        
    <target name="makeresource">
              <delete file="${resource.dir}/ApplicationResources_zh_CN.properties"/>
              <native2ascii src="${resource.dir}" dest="${resource.dir}" includes="ApplicationResources_cn.properties" encoding="GBK">
                 <mapper refid="resourcemapper"/>
    <mapper id="resourcemapper" type="glob" from="*_cn.properties" to="*_zh_CN.properties"/>
              </native2ascii>
           </target>

                                                            

    posted on 2005-03-08 23:53 笨笨 閱讀(584) 評(píng)論(0)  編輯  收藏 所屬分類: ALLAppFuse
    主站蜘蛛池模板: 久久精品国产亚洲一区二区三区| 特级做a爰片毛片免费看| 亚洲色无码一区二区三区| 在线免费视频一区| 67pao强力打造高清免费| 在线观看免费黄网站| 理论片在线观看免费| 亚洲天然素人无码专区| 亚洲精品在线免费观看| 国产亚洲福利精品一区| 亚洲精品国产va在线观看蜜芽| 永久免费bbbbbb视频| 成年18网站免费视频网站| 69xx免费观看视频| 中文字幕免费视频| 久艹视频在线免费观看| 西西人体免费视频| a级毛片免费完整视频| 中文字幕免费在线看线人动作大片| 精品国产免费观看久久久| 99无码人妻一区二区三区免费 | 亚洲精品人成无码中文毛片| 永久黄网站色视频免费观看| 妞干网免费观看视频| 毛片免费全部免费观看| 国拍在线精品视频免费观看| 日本一区二区三区免费高清| 免费精品国产自产拍在| 99久久99久久精品免费看蜜桃| 日本h在线精品免费观看| 亚洲成年人免费网站| 综合在线免费视频| 91免费国产在线观看| 成人免费无码视频在线网站| 一个人看www在线高清免费看 | 中文日韩亚洲欧美制服| 亚洲伊人久久大香线蕉AV| 亚洲国产精品嫩草影院| 黄色免费网址大全| 久久久久久噜噜精品免费直播| a级毛片在线免费|