《電子技術(shù)應(yīng)用》
您所在的位置:首頁(yè) > 其他 > 業(yè)界動(dòng)態(tài) > Web與EJB的分離

Web與EJB的分離

J2EE設(shè)計(jì)模式的使用
2008-12-30
作者:陳道成
1 設(shè)計(jì)背景
??? 目前, 業(yè)務(wù)層和實(shí)現(xiàn)層之間的必要分隔已成為應(yīng)用程序" title="應(yīng)用程序">應(yīng)用程序規(guī)劃和實(shí)現(xiàn)中最復(fù)雜的問(wèn)題之一。為了實(shí)現(xiàn)這一分隔,Brett McLaughlin 以業(yè)務(wù)接口(Business Interface)模式為基礎(chǔ),用JavaBean來(lái)處理業(yè)務(wù)邏輯上的 Web 層抽象。而這里,我們將使用業(yè)務(wù)接口模式和Session Bean ,使 Web 層與 Enterprise JavaBeans 組件保持松散耦合。通過(guò)將表示業(yè)務(wù)邏輯的代碼接口中抽象出業(yè)務(wù)邏輯實(shí)現(xiàn),以解決核心問(wèn)題。
2 設(shè)計(jì)實(shí)現(xiàn)" title="設(shè)計(jì)實(shí)現(xiàn)">設(shè)計(jì)實(shí)現(xiàn)
??? 首先我們引入業(yè)務(wù)接口模式,業(yè)務(wù)接口模式的實(shí)現(xiàn)允許我們提供特定于業(yè)務(wù)邏輯的接口,用于與Session Bean 交互。在 pro _1中,我們定義一個(gè)業(yè)務(wù)接口Istdudent, 可以看出IStudent 接口不包含任何 EJB 語(yǔ)義, 所有的實(shí)現(xiàn)和 EJB 細(xì)節(jié)都在Session? Bean 內(nèi)處理, 由Session? Bean 實(shí)現(xiàn)該接口。
pro_1. Student 業(yè)務(wù)接口
package edu.biti.stu;
import edu.biti.exceptions.NoStudentException;
import java.rmi.RemoteException;
public interface Istudent
{? public String? getName() throws RemoteException;
?? public long???? getStuNo(String category) throws RemoteException;
?? public boolean identify(long stuNo) throws RemoteException;
}
現(xiàn)在,讓我們看一下Web 層是如何訪問(wèn) Istudent 接口和Session Bean的:
pro_2. 使用 IStudent 接口
StudentHome stuHome =
???? (StudentHome)EJBHomeFactory.getInstance().
???? lookup("java:comp/env/ejb/StudentHome",
???????????????? StudentHome.class);
IStudent stu = stuHome.create();
??? 在pro_2通過(guò)查詢 Student bean 的 home 接口,然后從 home 接口獲得 IStudent 接口的實(shí)現(xiàn)。我們可以看到上述代碼并沒(méi)有采取常用訪問(wèn)EJB的放方式--裝入 JNDI 初始上下文、手工獲得 home 接口,隨后直接處理 企業(yè)bean—而是在此基礎(chǔ)上做了進(jìn)一步改進(jìn), 用到另外一個(gè)類EJBHomeFactory,我想凡了解設(shè)計(jì)模式" title="設(shè)計(jì)模式">設(shè)計(jì)模式的,對(duì)此一定不會(huì)陌生,的確他用到了另一種設(shè)計(jì)模式—工廠模式(Factory)。但它存在一個(gè)基本的缺點(diǎn)是:Web 層與 EJB 組件,尤其與 Student Session Bean(不僅是業(yè)務(wù)接口),并沒(méi)有完全分離。假如我們不用EJB,而使用 Java Data Object(JDO)或用EJB的一個(gè)新版本時(shí), 那么這時(shí)應(yīng)用程序代碼都必須作較大的改動(dòng)! 雖然目前比較容易編寫(xiě)緊密耦合的代碼,但這樣做必然是以犧牲應(yīng)用程序的使用壽命" title="使用壽命">使用壽命為代價(jià)的。那么如何實(shí)現(xiàn)層次清楚的系統(tǒng)的體系結(jié)構(gòu)(這是必然趨勢(shì)), 繼而使應(yīng)用程序更具維護(hù)性和可擴(kuò)展性" title="可擴(kuò)展性">可擴(kuò)展性呢?為解決這一問(wèn)題, 我們?cè)诖艘霕I(yè)務(wù)代理模式。
??? 業(yè)務(wù)代理模式與業(yè)務(wù)接口模式完全不同。業(yè)務(wù)接口模式僅僅定義了業(yè)務(wù)邏輯接口,具體的實(shí)現(xiàn)用Session Bean完成,而業(yè)務(wù)代理并不是接口,它提供了對(duì)業(yè)務(wù)邏輯的訪問(wèn),但不存在與其實(shí)現(xiàn)( Session EJB)組件的相關(guān)性。事實(shí)上,業(yè)務(wù)代理是一個(gè)helper類,用以與 EJB 容器交互、獲取資源以及釋放資源。
??? 具體實(shí)現(xiàn)參見(jiàn)Pro_3。
pro_3. 用于 Student? bean 的業(yè)務(wù)代理
package edu.biti.stu;
import java.rmi.RemoteException;
import javax.naming.NamingException;
public class StudentDelegate implements IStudent
{? private IStudent student;
?? public StudentDelegate()
{? init();
? }
? public void init()
{? try
???? {? // 查詢并獲取EJB
??????? StudentHome StudentHome =
????????????? (StudentHome)EJBHomeFactory.getInstance().lookup(
????????????????? "java:comp/env/ejb/StudentHome", StudentHome.class);
??????? Student = StudentHome.create();
}
catch (Exception e)
{? e.printStackTrace();
???? }
public String? getName() throws StudentException
{? try
??????? {? return? student.getName();
??????? }
catch (RemoteException e)
{? e.printStackTrace();
??????? }
???? }
public long getStuNo() throws StudentException
{? try
??????? {? return Student.getStuNo();
??????? }
catch (RemoteException e)
{? e.printStackTrace();
??????? }
???? }
public boolean? identify(long stuNo) throws StudentException
{? try
??????? {? return student. identify (stuNo);
??????? }
catch (RemoteException e)
{? e.printStackTrace();
??????? }
???? }
????? //……..
}
????在 StudentDelegate 類中,每個(gè)方法都可以響應(yīng)傳遞給Session? bean的請(qǐng)求。用init() 方法進(jìn)行初始化資源。這樣StudentDelegate就除去了應(yīng)用程序 Web 層之間的相關(guān)性。在應(yīng)用中我們只需如下調(diào)用即可:
IStudent stu = new StudentDelegate();
結(jié)束語(yǔ)
????本文通過(guò)對(duì)j2ee設(shè)計(jì)模式的使用,實(shí)現(xiàn)了web與EJB的分離,可見(jiàn),在web 層代碼清晰、簡(jiǎn)潔,根本不涉及EJB層的代碼,大大方便了以后程序的維護(hù)和修改工作。以后如果需要從使用 EJB 移植到使用純 JDO,那么可進(jìn)需要用新的 JDO類來(lái)重寫(xiě)業(yè)務(wù)代理就可以了。而 這一變化并不會(huì)影響Web 層,所以WEB層根本不需要重新編譯和修改,大大降低了所編碼的工作量。
參考文獻(xiàn):
1.?Srikanth Shenoy? 《Best practices in EJB exception handling》? developerWorks, 2002 .5
2.?developerWorks Java
3.?TheServerSide.com
4.?sun.java.com? J2ee design pattern
本站內(nèi)容除特別聲明的原創(chuàng)文章之外,轉(zhuǎn)載內(nèi)容只為傳遞更多信息,并不代表本網(wǎng)站贊同其觀點(diǎn)。轉(zhuǎn)載的所有的文章、圖片、音/視頻文件等資料的版權(quán)歸版權(quán)所有權(quán)人所有。本站采用的非本站原創(chuàng)文章及圖片等內(nèi)容無(wú)法一一聯(lián)系確認(rèn)版權(quán)者。如涉及作品內(nèi)容、版權(quán)和其它問(wèn)題,請(qǐng)及時(shí)通過(guò)電子郵件或電話通知我們,以便迅速采取適當(dāng)措施,避免給雙方造成不必要的經(jīng)濟(jì)損失。聯(lián)系電話:010-82306118;郵箱:aet@chinaaet.com。