Jive論壇與Spring框架,經(jīng)典代碼和架構(gòu)!
Jive論壇與Spring框架板橋里人 http://www.jdon.com 2004/07/01
沒(méi)有一種新技術(shù)是憑空誕生的,它的萌芽或胚胎總是或多或少顯現(xiàn)于以前的技術(shù)中,Jive論壇是大家潛心研究的設(shè)計(jì)型應(yīng)用程序,其相關(guān)解析可見(jiàn)本欄的GoF設(shè)計(jì)模式專欄。
Jive和Spring同為由JavaBeans組成的J2EE Web系統(tǒng),Jive作為早期成功設(shè)計(jì)案例,其主要架構(gòu)成為大多數(shù)純JavaBeans系統(tǒng)的流行架構(gòu),Spring也不例外。
Spring框架除了是一種Web層應(yīng)用框架,還提供了訪問(wèn)EJB層的接口,也有JDBC/ORM的直接操作。Spring框架主要魅力是使用IoC模式和AOP實(shí)現(xiàn)了Jive系統(tǒng)的通用功能,從而使得Jive這樣的純JavaBeans架構(gòu)設(shè)計(jì)可以重用在其它系統(tǒng)中。
如果你感慨于Jive的設(shè)計(jì)理念,但是又苦于無(wú)法重用其設(shè)計(jì)時(shí),Spring框架已經(jīng)幫你實(shí)現(xiàn)了。
同時(shí)也要注意到:Spring框架類似“雜燴”,它包含了很多J2EE應(yīng)用的工具,類如對(duì)EJB的調(diào)用,它的MVC與Struts JSF也是相競(jìng)爭(zhēng)的,以純Ioc和AOP設(shè)計(jì)來(lái)說(shuō),Spring框架也是一種很重的(Heavy、Weight)框架。Spring框架是復(fù)雜的,如果想以Spring替代EJB,那么無(wú)疑按了葫蘆浮起瓢。
將Jive論壇和Spring框架聯(lián)系起來(lái),會(huì)幫助更多理解設(shè)計(jì)模式的程序員迅速掌握最新的設(shè)計(jì)思潮,而不是一種跳躍式的強(qiáng)迫接受。如果你對(duì)Jive有很好的研究,將會(huì)發(fā)現(xiàn)Spring框架是Jive設(shè)計(jì)的更加通用的提升。
在Jive中,ForumFactory是整個(gè)系統(tǒng)的入口和突破點(diǎn),Jive通過(guò)ForumFactory將整個(gè)系統(tǒng)掌控在一個(gè)工廠模式下,這樣做的好處是:便于控制系統(tǒng)的JavaBeans,例如,客戶端通過(guò)ForumFactory可創(chuàng)建一個(gè)Forum或訪問(wèn)一個(gè)Forum,但是是否有權(quán)限訪問(wèn)呢?如下圖:
Jive通過(guò)ForumFactory將這種訪問(wèn)引導(dǎo)到相應(yīng)的Proxy類去,如ForumFactoryProxy類等,通過(guò)代理模式對(duì)這些類進(jìn)行權(quán)限控制訪問(wèn)。這是代理模式的一個(gè)主要用處,但是研讀Jive的代理模式會(huì)發(fā)現(xiàn),要為每個(gè)類實(shí)現(xiàn)一個(gè)Proxy類,非常瑣碎,有沒(méi)有更優(yōu)雅的方式呢? 當(dāng)然使用動(dòng)態(tài)代理。
Spring框架基本是抽象上述設(shè)計(jì),Spring框架對(duì)所有JavaBeans的管理也是基于一個(gè)總?cè)肟贐ean Factory機(jī)制,不同的是,BeanFactory可以 管理所有應(yīng)用的JavaBeans,使用者只要將自己的JavaBeans通過(guò)配置文件告訴BeanFactory,那么BeanFactory將會(huì)加載這些JavaBeans,例如:
<beans>
<bean id="exampleBean" class="eg.ExampleBean"/>
<bean id="anotherExample" class="eg.ExampleBeanTwo"/>
</beans>
在Jive中,F(xiàn)orumFactory加載Jive自己的JavaBeans是通過(guò)工廠實(shí)現(xiàn)DbForumFactory實(shí)現(xiàn)的,如下代碼,DbForumFactory引發(fā)了后臺(tái)一系列功能實(shí)現(xiàn),這是縱向,而return new ForumFactoryProxy這個(gè)語(yǔ)句則類似引來(lái)一個(gè)切面,從一個(gè)橫向方面實(shí)現(xiàn)了權(quán)限訪問(wèn)等功能:
private static String className = "com.jivesoftware.forum.database.DbForumFactory"; public static ForumFactory getInstance(Authorization authorization) { try { //Now, 返回 proxy.用來(lái)限制授權(quán)對(duì)forum的訪問(wèn) |
既然Spring框架也是通過(guò)一個(gè)Bean Factory加載所有的類,那么它是如何加載的?通過(guò)IoC模式,也就是依賴性注射模式。在我以前文章“IoC模式”中,我比較了Factory工廠模式創(chuàng)建對(duì)象和Ioc模式的注射對(duì)象實(shí)現(xiàn)之間的異同,Ioc相比工廠模式則更加解耦了調(diào)用者和被調(diào)用者之間關(guān)系,使用Ioc模式,無(wú)需在調(diào)用者代碼中涉及被調(diào)用者的具體實(shí)現(xiàn)。
Spring框架不但可以向自己容器中注射應(yīng)用者自己定義的JavaBeans(也就是創(chuàng)建它們),而且也可以向這些JavaBeans通過(guò)set方法實(shí)現(xiàn)數(shù)據(jù)賦值。
一旦Bean Factory運(yùn)行時(shí)刻掌管這些激活的對(duì)象,Spring通過(guò)AOP方式,從一個(gè)橫切面為這些JavaBeans提供了權(quán)限訪問(wèn)、事務(wù)鎖等通用功能的實(shí)現(xiàn),這種實(shí)現(xiàn)是基于動(dòng)態(tài)代理模式,而動(dòng)態(tài)代理是AOP實(shí)現(xiàn)的一種方式。
前面提到,Jive中使用代理模式實(shí)現(xiàn)權(quán)限訪問(wèn),比代理模式更加簡(jiǎn)潔和抽象的是動(dòng)態(tài)代理,使用動(dòng)態(tài)代理將使得調(diào)用者無(wú)需指定被調(diào)用者的代理類,這是動(dòng)態(tài)代理區(qū)別代理模式的本質(zhì)。
動(dòng)態(tài)代理這一優(yōu)勢(shì),又可以體現(xiàn)在另外一句話語(yǔ)上:動(dòng)態(tài)代理攔截了調(diào)用者對(duì)被調(diào)用者的調(diào)用,正是這一功能符合了AOP的攔截器功能,為AOP實(shí)現(xiàn)提供了可能。
Spring框架使用了動(dòng)態(tài)代理實(shí)現(xiàn)的AOP,正是通過(guò)動(dòng)態(tài)代理機(jī)制攔截了外界對(duì)Bean Factory管理下的對(duì)象的調(diào)用。如下圖:
以上只是大體解構(gòu)了Spring的架構(gòu),Spring框架在這個(gè)架構(gòu)下,還順帶了很多其它功能,如Web MVC、 DAO JDBC、 DAO ORM 、以及remote,后者類似我設(shè)計(jì)的EJB方法調(diào)用框架。
總之,Spring確實(shí)是Ioc和AOP的完美應(yīng)用,Ioc用來(lái)裝載JavaBeans,創(chuàng)建這些對(duì)象;AOP用來(lái)攔截這些對(duì)象的使用,這才是框架設(shè)計(jì)的必然經(jīng)典方式。
ZT:
http://www.zahui.com/html/6/40477.htm
posted on 2005-05-18 23:46 Vikings 閱讀(400) 評(píng)論(0) 編輯 收藏 所屬分類: frame-work