提供基于jt808協(xié)議的服務器Java源碼實現(xiàn)
Struts2的前景還是穩(wěn)健的,使用的人數(shù)在不斷的增加。參看struts 2依然堅挺 Seam前景不明但基于Struts2的開發(fā),如果沒有足夠的經驗和規(guī)范做支撐,并不能帶來還多的好處,如果失控,一樣和JSP+servlet泛濫,這一點需要警示。1).Action類及Action Name的命名規(guī)范? Action類的后綴統(tǒng)一加上"Action", ? Action的Name與類的名稱保持一致,但不要"Action"的后綴。? 這樣是為了通過Action的調用url, 很方便的找到Action類。
?
? 如上,看到/searchKnowledge.action,就可以很清楚的知道類是SearchKnowledgeAction了。很多人不注重這一點,開發(fā)調試中,每次都要笨拙的看struts.xml文件。
2).每個項目都必須至少有一個公用的Action類,GenericAction? 完成的功能如下:? 1.獲取、注入request? 2.獲取、注入Session? 3.錯誤頁面跳轉? 4.獲取在線用戶和會員的信息(個人信息、權限、角色等)? 5.注入類型轉換的格式轉換類,如日期類型轉換:ConvertUtils.register(new DateConverter(), Date.class);? 6.獲取系統(tǒng)配置信息,如公用變量(如配置路徑等)? 7.對于request參數(shù)的處理等? 8.其他可擴展的操作
3).擅長使用Dispatch的模式? 有人說Action,不就是Dispatch的延伸嗎,其實還可以做的更好。
? 這個典型的模式如下:? 1.頁面表單的Hidden參數(shù)中,就是一個ID,如queryID="queryKnowledges". Action="/paginate.action"
? 2.PaginateAction的模板如下
????? 3.在struts.xml中進行配置與queryID想對應:?
?? 實戰(zhàn)代碼如下:??
4).配置文件的目錄結構?
5).不斷的提煉公用的Action,并放在一個package中:? 如上傳、下載、異常處理、excel數(shù)據(jù)錄入、過濾器(filter)、截取器(inteceptor)等等?
6).將一個模塊中的Action放置在一起???
7).擅與使用redirect來保持request參數(shù).? 使用redirect一樣可以將request參數(shù)傳遞到下一頁面中,不需要使用session.? viewPost?postid=${postid}?
8)靈活使用chain模式,來編寫簡短而高度重用的Action,把相關的幾個action連接起來,共同完成一個功能。????? 同一個Chain的多個action間數(shù)據(jù)的傳遞非常方便,由于處于chain中的action屬于同一個http請求,共享一個ActionContext,故可以在上下文中獲取,在頁面上可以直接使用,上一個Action的成員變量。??????
9) 編寫簡潔而高度重用的Action的另一個方法,就是將頁面的渲染,格式轉換的邏輯,抽取出來,自定義成Result。官方的Result
10) 明確Action類不要超長,如不要超過500行代碼。???? 很多人為了偷懶,喜歡在一個Action中,不斷的添加方法,而不管這些方法與Action的語義是否符合,到底是多個Action,還是多個方法,在開發(fā)過程中,還是要注重這些方法是否與創(chuàng)建Action類的目的、語義保持一致。???? 最好明確代碼的長度,團隊人多,手雜,水平不一,為了保證可維護性,這是一個不得已的方法。
posted on 2008-11-27 08:54 Speed 閱讀(4826) 評論(5) 編輯 收藏 所屬分類: 框架設計 、struts2 、J2EE
GenericAction 貼出來一個看看 回復 更多評論
3).擅長使用Dispatch的模式樓主這條應該可以再斟酌 回復 更多評論
很實用的東東,謝謝分享,期待更多精彩! 回復 更多評論
try annotation and you will find it amazing... 回復 更多評論
似乎這幾點是所有的編程人員都要有的習慣! 回復 更多評論