新聞中心
Hibernate還是比較常用的,于是我研究了一下Hibernate ActionFormBean,在這里拿出來和大家分享一下,希望對大家有用。

在struts+Hibernate這種結(jié)構(gòu)中,是不應(yīng)該把Hibernate產(chǎn)生的PO直接傳遞給JSP的,不管他是Iterator,還是List,這是一個設(shè)計錯誤。
我來談?wù)勗贘2EE架構(gòu)中各層的數(shù)據(jù)表示方法:Web層的數(shù)據(jù)表示是FormBean,數(shù)據(jù)來源于HTML Form POST業(yè)務(wù)層的數(shù)據(jù)表示是VO持久層的數(shù)據(jù)表示是PO,其數(shù)據(jù)來源于數(shù)據(jù)庫,持久層的數(shù)據(jù)表示例如CMP在一個規(guī)范的J2EE架構(gòu)中,不同層的數(shù)據(jù)表示應(yīng)該被限制在層內(nèi),而不應(yīng)該擴散到其它層,這樣可以降低層間的耦合性,提高J2EE架構(gòu)整體的可維護性和可擴展性。比如說Web層的邏輯進行了修改,那么只需要修改FormBean的結(jié)構(gòu),而不需要觸動業(yè)務(wù)層和持久層的代碼修改。同樣滴,當(dāng)數(shù)據(jù)庫表進行了小的調(diào)整,那么也只需要修改持久層數(shù)據(jù)表示,而不需要觸動業(yè)務(wù)層代碼和Web層代碼。
不過由于Hibernate的強大功能,例如動態(tài)生成PO,PO的狀態(tài)管理可以脫離Session,使得在應(yīng)用了Hibernate的J2EE框架中,PO完全可以充當(dāng)VO,因此我們下面把PO和VO合并,統(tǒng)稱為PO.先來談?wù)凙ctionFormBean和持久層的PO之間的重大區(qū)別。
在簡單的應(yīng)用中,Hibernate ActionFormBean和PO幾乎是沒有區(qū)別,所以很多人干脆就是用ActionFormBean來充當(dāng)PO,于是ActionFormBean從JSP頁面到Servlet控制層再到業(yè)務(wù)層,然后穿過持久層,最后一直映射到數(shù)據(jù)庫表。真是一竿子捅到了底!
但是在復(fù)雜的應(yīng)用中,ActionFormBean和PO是分離的,他們也不可能一樣。ActionFormBean是和網(wǎng)頁里面的Form表單一一對應(yīng)的,F(xiàn)orm里面有什么元素,Bean里面就有什么屬性。而PO和數(shù)據(jù)庫表對應(yīng),因此如果數(shù)據(jù)庫表不修改,那么PO也不會修改,如果頁面的流程和數(shù)據(jù)庫表字段對應(yīng)關(guān)系不一致,那么你又如何能夠使用ActionFormBean來取代PO呢?
比如說吧,用戶注冊頁面要求注冊用戶的基本信息,因此HTML Form里面包含了基本信息屬性,于是你需要一個ActionFormBean來一一對應(yīng)(注意:是一一對應(yīng)),每個Bean屬性對應(yīng)一個文本框或者選擇框什么的。
而用戶這個持久對象呢?他的屬性和ActionFormBean有什么明顯不同呢?他會有一些ActionFormBean所沒有的集合屬性,比如說用戶的權(quán)限屬性,用戶的組屬性,用戶的帖子等等。另外還有可能的是在ActionFormBean里面有3個屬性,分別是用戶的First Name, Middle Name, Last Name,而在我的User這個持久對象中就是一個 Name 對象屬性。
假設(shè)我的注冊頁面原來只要你提供First Name,那么ActionFormBean就這一個屬性,后來我要你提供全名,你要改ActionFormBean,加兩個屬性。但是這個時候PO是不應(yīng)該修改滴,因為數(shù)據(jù)庫沒有改。
那么在一個完整的J2EE系統(tǒng)中應(yīng)該如何進行合理的設(shè)計呢?
JSP(View) ——> ActionFormBean(Module) ——> Action(Control)
Hibernate ActionFormBean是 Web層的數(shù)據(jù)表示,它和HTML頁面Form對應(yīng),只要Web頁面的操作流程發(fā)生改變,它就要相應(yīng)的進行修改,它不應(yīng)該也不能被傳遞到業(yè)務(wù)層和持久層,否則一旦頁面修改,會一直牽連到業(yè)務(wù)層和持久層的大面積的代碼進行修改,對于軟件的可維護性和可擴展性而言,是一個災(zāi)難,Actiont就是他的邊界,到此為止!
Action(Web Control) ——> Business Bean ——> DAO ——> ORM ——>DB而PO則是業(yè)務(wù)層和持久層的數(shù)據(jù)表示,它在業(yè)務(wù)層和持久層之間進行流動,他不應(yīng)該也不能被傳遞到Web層的View中去,而 ActionServlet就是他的邊界,到此為止!
當(dāng)前題目:HibernateActionFormBean簡介
文章起源:http://fisionsoft.com.cn/article/cdeiojj.html


咨詢
建站咨詢
