EJB技術及應用

來源:互聯網
上載者:User
一、EJB技術簡介
EJB的全稱是Enterprise java bean。是JAVA中的商業應用組件技術。EJB結構中的角色 EJB 組件結構是基於組件的分散式運算結構,是分布式應用系統中的組件。
一個完整的基於EJB的分散式運算結構由六個角色群組成,這六個角色可以由不同的開發商提供,每個角色所作的工作必須遵循Sun公司提供的EJB規範,以保證彼此之間的相容性。這六個角色分別是EJB組件開發人員(Enterprise Bean Provider) 、應用組合者(Application Assembler)、部署者(Deployer)、EJB 伺服器提供者(EJB Server Provider)、EJB 容器提供者(EJB Container Provider)、系統管理員(System Administrator):

二、EJB中各角色的分析

1、EJB組件開發人員(Enterprise Bean Provider)
EJB組件開發人員負責開發執行商業邏輯規則的EJB組件,開發出的EJB組件打包成ejb-jar檔案。EJB組件開發人員負責定義EJB的remote和home介面,編寫執行商業邏輯的EJB class,提供部署EJB的部署檔案(deployment descriptor)。部署檔案包含EJB的名字,EJB用到的資源配置,如JDBC等。EJB組件開發人員是典型的商業應用開發領域專家。
EJB組件開發人員不需要精通系統級的編程,因此,不需要知道一些系統級的處理細節,如事務、同步、安全、分散式運算等。

2、應用組合者(Application Assembler)
應用組合者負責利用各種EJB組合一個完整的應用系統。應用組合者有時需要提供一些相關的程式,如在一個電子商務系統裡,應用組合者需要提供JSP(Java Server Page)程式。
應用組合者必須掌握所用的EJB的home和remote介面,但不需要知道這些介面的實現。

3、部署者(Deployer)
部署者負責將ejb-jar檔案部署到使用者的系統內容中。系統內容包含某種EJB Server和EJB Container。部署者必須保證所有由EJB組件開發人員在部署檔案中聲明的資源可用,例如,部署者必須配置好EJB所需的資料庫資源。
部署過程分兩步:部署者首先利用EJB Container提供的工具產生一些類和介面,使EJB Container能夠利用這些類和介面在運行狀態管理EJB。 部署者安裝EJB組件和其他在上一步產生的類到EJB Container中。 部署者是某個EJB運行環境的專家。
某些情況下,部署者在部署時還需要瞭解EJB包含的業務方法,以便在部署完成後,寫一些簡單的程式測試。

4、EJB 伺服器提供者(EJB Server Provider)
EJB 伺服器提供者是系統領域的專家,精通分布式交易管理,分布式對象管理及其它系統級的服務。EJB 伺服器提供者一般由作業系統開發商、中介軟體開發商或資料庫開發商提供。
在目前的EJB規範中,假定EJB 伺服器提供者和EJB 容器提供者來自同一個開發商,所以,沒有定義EJB 伺服器提供者和EJB容器提供者之間的介面標準。

5、EJB 容器提供者(EJB Container Provider)
EJB 容器提供者提供以下功能:
提供EJB部署工具為部署好的EJB組件提供運行環境 。EJB容器負責為EJB提供交易管理,安全管理等服務。
EJB 容器提供者必須是系統級的編程專家,還要具備一些應用領域的經驗。EJB 容器提供者的工作主要集中在開發一個可伸縮的,具有交易管理功能的整合在EJB 伺服器中的容器。EJB 容器提供者為EJB組件開發人員提供了一組標準的、易用的API訪問EJB 容器,使EJB組件開發人員不需要瞭解EJB伺服器中的各種技術細節。
EJB容器提供者負責提供系統監測工具用來即時監測EJB容器和運行在容器中的EJB組件狀態。

6、系統管理員(System Administrator)
系統管理員負責為EJB伺服器和容器提供一個企業級的計算和網路環境。
系統管理員負責利用EJB 伺服器和容器提供的監測管理工具監測EJB組件的運行情況。

三、EJB的體繫結構:

EJB分布式應用程式是基於對象組件模型的,低層的事務服務用了API技術。EJB技術簡化了用JAVA語言編寫的公司專屬應用程式系統的開發,配置。EJB技術定義了一組可重用的組件:Enterprise Beans。你可以利用這些組件,象搭積木一樣的建立你的分布式應用程式。當你把代碼寫好之後,這些組件就被組合到特定的檔案中去。每個檔案有一個或多個Enterprise Beans,在加上一些配置參數。最後,這些Enterprise Beans被配置到一個裝了EJB容器的平台上。客戶能夠通過這些Beans的home介面,定位到某個beans,併產生這個beans的一個執行個體。這樣,客戶就能夠調用Beans的應用方法和遠程介面。
EJB伺服器作為容器和低層平台的橋樑管理著EJB容器和函數。它向EJB容器提供了訪問系統服務的能力。例如:資料庫的管理和事務的管理,或者對於其它的Enterprise的應用伺服器。所有的EJB 執行個體都運行在EJB容器中。 容器提供了系統級的服務,控制了EJB的生命週期。EJB中的有一些便於使用的管理工具如:Security--配置描述器(The Deployment descriptor)定義了客戶能夠訪問的不同的應用函數。容器通過只允許授權的客戶訪問這些函數來達到這個效果。Remote Connectivity--容器為遠程連結管理著低層的通訊issues,而且對Enterprise Beas的開發人員和客戶都隱藏了通訊細節。EJB的開發人員在編寫應用方法的時候,就象是在條用本地的平台一樣的。客戶也不清楚他們調用的方法可能是在遠程被處理的。Life Cycle managment--客戶簡單的建立一個Enterprise beans的執行個體,並通常取消一個執行個體。而容器管理著Enterprise Beans的執行個體,使Enterprise Beans實現最大的效能和記憶體利用率。容器能夠這樣來啟用和使Enterprise Beans失效,保持眾多客戶共用的執行個體池。等等。 Trasction management-配置描述器定義了Enterprise beans 的交易處理的需求。容器管理著那些管理分散式交易處理的複雜的issues。這些事務可能要在不同的平台之間更新資料庫。容器使這些事務之間互相獨立,互不干擾。保證所有的更新資料庫都是成功發生的,否者,就復原到交易處理之前的狀態。
EJB 組件是基於分散式交易處理的企業級應用程式的組件。所有的EJB都有如下的特點:EJB包含了處理企業資料的應用邏輯。定義了EJB的客戶介面。這樣的介面不受容器和伺服器的影響。於是,當一個EJB被集合到一個應用程式中去時,不用更改代碼和重新編譯。EJB能夠被定製 各種系統級的服務,例如安全和交易處理的特性,都不是屬於EJB類的。而是由配置和組裝應用程式的工具來實現。 有兩種類型的EJB: Session beans 和 entity beans.Session beans是一種作為單使用者執行的對象。作為對遠端工作要求的相應,容器產生一個Session beans 的執行個體。一個Session beans有一個使用者.從某種程度上來說,一個Session bean 對於伺服器來說就代表了它的那個使用者.Session beans 也能用於事務,它能夠更新共用的資料,但它不直接描繪這些共用的資料。Session beans 的生命週期是相對較短的。典型的是,只有當使用者保持會話的時候,Session beans 才是活著的。一旦使用者退出了,Session beans 就不再與使用者相聯絡了。Session beans被看成是瞬時的,因為如果容器崩潰了,那麼使用者必須重建立立一個新的Session對象來繼續會話。
Session bean典型的聲明了與使用者的互操作或者會話。也就是說,Session bean了在客戶會話期間,通過方法的調用,掌握使用者的資訊。一個具有狀態的Session bean稱為有狀態的Session bean.當使用者終止與Session beans互操作的時候.會話終止了,而且,bean 也不再擁有狀態值。Session bean也可能是一個無狀態的 session bean.無狀態的Session beans並不掌握它的客戶的資訊或者狀態。使用者能夠調用beans的方法來完成一些操作。但是,beans只是在方法調用的時候才知道使用者的參數變數。當方法調用完成以後,beans並不繼續保持這些參數變數。這樣,所有的無狀態的session beans的執行個體都是相同的,除非它正在方法調用期間。這樣,無狀態的Session beans就能夠支援多個使用者.容器能夠聲明一個無狀態的Session beans.能夠將任何Session beans指定給任何使用者.
Entity Beans對資料庫中的資料提供了一種對象的視圖。例如:一個Entity bean能夠類比資料庫表中一行相關的資料。多個client能夠共用訪問同一個Entity bean.多個client也能夠同時的訪問同一個Entity bean.Entity beans通過事務的上下文來訪問或更新下層的資料。這樣,資料的完整性就能夠被保證。Entity Beans能存活相對教長的時間,並且狀態是持續的。只要資料庫中的資料存在,Entity beans就一直存活。而不是按照應用程式或者服務進程來說的。即使EJB容器崩潰了,Entity beans也是存活的。Entity Beans生命週期能夠被容器或者 Beans自己管理。如果由容器控制著保證 Entity beans持續的issus。如果由Beans自己管理,就必須寫Entity beans的代碼,包括訪問資料庫的調用。
Entity Beans是由主鍵(primary key 一種唯一的物件識別碼)標識的。通常,主鍵與標識資料庫中的一塊資料,例如一個表中的一行,的主鍵是相同的。主鍵是client能夠定位特定的資料區塊。

四、開發EJB

1、類介紹:
開發EJB的主要步驟一般來說,整個的開發步驟(開發,配置,組裝)包括如下幾個方面。開發:首先要定義三個類:Bean類本身,Bean的本地和遠程介面類。 配置:配置包括產生配置描述器--這是一個XML檔案、聲明了Enterprise Bean的屬性、綁定了bean的class檔案(包括stub檔案和skeleton檔案)。最後將這些配置都放到一個jar檔案中。還需要在配置器中定義環境屬性。組裝應用程式:包括將Enterprise beans安裝到Server伺服器中,測試各層的串連情況。程式組合器將若干個Enterprise Beans與其它的組件結合起來。組合成一個完整的應用程式。或者將若干個Enterprise beans組合成一個複雜的Enterprise Bean。管理Enterprise Bean。
我們必須定義和編寫一些EJB中的基本類。如Enterprise bean類:這是Enterprise bean內部應用邏輯的實現。編寫Enterprise bean的遠程介面類。編寫Enterprise bean的本地介面類。說明主鍵類,主鍵類只是對於Entity bean才需要的。在Enterprise bean的配置描述器中指定主鍵的名字。Enterprise beans提供者定義了遠程介面和本地介面,實現了EJB類本身。Remote介面中提供了客戶調用EJB實現的應用邏輯函數的介面。而home介面提供了產生和定位remote介面執行個體的方法。
在Enterprise bean本身類的實現,本地home介面,遠程remote介面之間並沒有正式的聯絡(例如繼承關係)。但是,在三個類裡聲明的方法卻必須遵守EJB裡面定義的規範。例如: 你在Enterprise bean裡面聲明了一個應用程式的方法或者說應用邏輯。也在beans的remote介面中聲明了這個方法,那麼,這兩個地方必須要同樣的名字。Bean的實現裡面必須至少有一個Create()方法:ejbCreate()。但是可以有多個帶有不同參數的create()方法。 在home介面中,也必須有相同的方法定義(參數的個數相同)。EjbCreate()方法返回的一個容器管理的持久對象。它們都返回一個容器管理持久性的主索引值。但是,在home的相應的Create()方法中傳回值的類型是remote介面。
注意:實體bean的實現的ejbCreate方法有點不同。實體bean可以不定義ejbCreate方法。如果實體只是通過應用程式或通過資料庫管理程式的途徑被加到資料庫中,實體bean就省略了ejbCreate方法。EjbCreate返回的值是主鍵類型。如果ejbCreate方法是容器管理持久性的實體bean的方法,它的傳回值就是NULL類型。如果實體bean實現了Bean管理的持久性,ejbCreate方法就傳回值類型就是主鍵類型。容器的任務是把各介面和Enterprise bean的實作類別結合起來。保證在編譯時間和運行時,各介面和實作類別是相對應的。
EJB的實作類別,各介面要從不同的基類中繼承下來。一個會話bean必須實現基類javax.ejb.SessionBean。而實體bean必須實現基類javax.ejb.EntiyBean。這些EJB的基類都是從javax.ejb.EnterpriseBean繼承而來。而javax.ejb.EnterpriseBean又是從java.io.Serializable繼承而來。每一個Enterprise Bean都必須有一個remote介面。Remote介面定義了應用程式規定客戶可以調用的邏輯操作。這些是一些可以由客戶調用的公用的方法,通常由Enterprise beans類來實現。注意,Enterprise bean的客戶並不直接存取Bean。而是通過remote介面來訪問。Enterprise bean類的remote介面擴充了javax.ejb.EJBObject類的公用java介面。而Javax.ejb.EJBObject是所有remote介面的基類。其代碼如下:

package javax.ejb;public interface EJBObject extends java.rmi.Remote{public EJBHome getEJBHome() throws java.rmi.RemoteException;public Object getPrimaryKey() throws java.rmi.RemoteException;public void Remove() throws java.rmi.RemtoeException, java.rmi.RemoveExceptionpublic Handle getHandle() throws java.rmi.RemoteException;boolean isIdentical (EJBObject p0) throws java.rmi.RemoteException;}

getEJBHome()方法允許你取得一個相關的Home介面。對於 實體Bean,用getPrimaryKey()方法獲得實體Bean的主索引值。Remove()可以刪除一個Enterprise bean。具體的語義在各種不同類型的enterprise beans的生命週期中,由上下文中解釋的。方法getHandle()返回了一個Enterprise bean執行個體的持久的控制代碼。IsIndentical()方法允許你去比較Enterprise beans是否相同。

2、方法:
所有的remote介面中的方法必須聲明為公用(public)的,並必須拋出java.rmi.RemotException異常。另外,所有的remote介面中的方法定義的參數和都必須是在RMI-IIOP中有效。對每一個在remote介面中定義的方法,在Enterprise bean 類裡面都要有相應的方法。相應的方法必須要有同樣的名字,同樣類型和數量的參數,同樣的傳回值,而且還要拋出同樣的例外。 如下代碼顯示了一個ATM例子的會話bean的remote介面Atm,。裡面聲明了一個應用方法transfer()。黑體部分表示EJB規範中必須要有的內容。Remote介面必須擴充javax.ejb.EJBObject類。從用戶端調用的Enterprise bean的每一個方法都必須在remote介面中聲明。Transfer()方法拋出了兩個意外。其中InSufficientFundsException例外是應用程式定義的意外。

Public interface Atm extends javax.ejb.EJBObject{Public void transfer(String Source, String Target, float amount)Throws java.rmi.RemoteException, InSufficientFundsException;}

Home介面必須定義一個或多個的Create()方法。每一個這樣的Create()方法都必須命名為Create。並且,它的參數,不管是類型還是數量都必須與bean類裡面的ejbCreate()方法對應。注意,home介面中的Create()方法和bean類中ejbCreate()方法的傳回值類型是不同的。實體bean的home介面還包含find()方法。 每一個Home介面都擴充了javax.ejb.EJBHome介面。如下代碼顯示了javax.ejb.EJBHome介面的定義:

package javax.ejb;public interface EJBHome extends java.rmi.Remote() {void remove(Handle handle) throws java.rmi.RemoteException,RemoveException;void remove(Object primarykey) throws java.rmi.RemoteException,RemoveException;EJBMetaData getEJBMetaData() throws RemoteException;Homehandle getHomeHandle() throws RemoteException;}

這裡提供了兩個remove()方法來刪除Enterprise bean的執行個體。第一個remove方法是通過控制代碼來刪除一個Enterprise bean的執行個體。第二個remove方法通過主鍵來刪除一個Enterprise bean的執行個體。 在眾多的Enterprise bean執行個體中,控制代碼唯一的標識一個執行個體。一個控制代碼與它引用的Enterprise bean有相同的生命期。考慮一個實體物件,客戶可以通過一個控制代碼來重新獲得相應的Enterprise bean的執行個體。一個控制代碼能夠對應一個Enterprise bean對象的多個執行個體。例如,即使當Enterprise bean對象所在的主機崩潰了,或者Enterprise bean對象在不同的機器之間移動,控制代碼仍是有效。這裡的控制代碼是Serialized控制代碼,與CORBA中的字串化的CORBA對象的引用是相似的概念。在EJBHome介面中的第二個remove操作通過其主鍵來決定要刪除的Enterprise bean。主鍵可以是擴充了Java Object類的任何類型,但是,必須要實現Java的Serializable介面。主鍵是標識實體bean的主要的方法。通常,主鍵是資料庫中的一個關鍵字,唯一的定義了由實體bean代表的資料。
方法getEJBMetaData()返回了Enterprise bean對象的metadata介面。這個介面允許客戶獲得Enterprise bean的metadata資訊。當開發工具來編譯連結應用程式的時候,或者組態工具來配置的時候,可能會用到metadata資訊。Javax.ejb.EJBMetadata介面提供了獲得javax.ejb.EJBHome介面,home類,remote介面,還有獲得主鍵的方法。也提供了一個isSesson()的方法來確定在放這個home介面的對象是會話bean還是實體bean。 IsStatelessSession()方法指示這個會話bean是有狀態還是無狀態的。如下代碼顯示了javax.ejb.EJBMetadata介面的定義部分的代碼。

Public javax.ejb; Public interface EJBMetaData{EJBHome getEJBHome();Class getHomeInterfaceClass();Class getRemoteInterfaceClasss();Class getPrimaryKeyClass();Boolean isSession();Boolean isStatelesssSession();}

對每一個Create()方法,EJB規範定義了如下的命名規範。它的傳回值是會話bean的remote介面的類型。方法的名字只能是Create()。對會話bean類中的每一個ejbCreate()方法都必須有一個Create()與之對應。 對於每一個Create()方法的參數的類型和數量都必須與會話bean類中的ejbCreate()方法相對應。方法必須拋出java.rmi.RemoteException例外。 方法必須拋出javax.rmi.CreateExeption例外。 Create()方法的參數是用來初始化新的會話bean對象的。 如下代碼顯示了一個會話bean對象的不同的Create()方法,其中必須的部分用粗體顯示:

public interface AtmHome extends javax.ejb.EJBHome{Atm create() throws java.rmi.RemoteException,javax.ejb.CreateException;Atm create(Profile preferredProfile)Throws java.rmi.RemoteExeption,javax.ehrows java.rmi.RemoteException,RemoveException;EJBMetaData getEJBMetaData() throws RemoteException;Homehandle getHomeHandle() throws RemoteException;}

這裡提供了兩個remove()方法來刪除Enterprise bean的執行個體。第一個remove方法是通過控制代碼來刪除一個Enterprise bean的執行個體。第二個remove方法通過主鍵來刪除一個Enterprise bean的執行個體。在眾多的Enterprise bean執行個體中,控制代碼唯一的標識一個執行個體。一個控制代碼與它引用的Enterprise bean有相同的生命期。考慮一個實體物件,客戶可以通過一個控制代碼來重新獲得相應的Enterprise bean的執行個體。一個控制代碼能夠對應一個Enterprise bean對象的多個執行個體。例如,即使當Enterprise bean對象所在的主機崩潰了,或者Enterprise bean對象在不同的機器之間移動,控制代碼仍是有效。這裡的控制代碼是Serialized控制代碼,與CORBA中的字串化的CORBA對象的引用是相似的概念。
在EJBHome介面中的第二個remove操作通過其主鍵來決定要刪除的Enterprise bean。主鍵可以是擴充了Java Object類的任何類型,但是,必須要實現Java的Serializable介面。主鍵是標識實體bean的主要的方法。通常,主鍵是資料庫中的一個關鍵字,唯一的定義了由實體bean代表的資料。方法getEJBMetaData()返回了Enterprise bean對象的metadata介面。這個介面允許客戶獲得Enterprise bean的metadata資訊。當開發工具來編譯連結應用程式的時候,或者組態工具來配置的時候,可能會用到metadata資訊。Javax.ejb.EJBMetadata介面提供了獲得javax.ejb.EJBHome介面,home類,remote介面,還有獲得主鍵的方法。也提供了一個isSesson()的方法來確定在放這個home介面的對象是會話bean還是實體bean。IsStatelessSession()方法指示這個會話bean是有狀態還是無狀態的。如下代碼顯示了javax.ejb.EJBMetadata介面的定義部分的代碼。

Public javax.ejb;Public interface EJBMetaData{EJBHome getEJBHome();Class getHomeInterfaceClass();Class getRemoteInterfaceClasss();Class getPrimaryKeyClass();Boolean isSession();Boolean isStatelesssSession();}

五、EJB的編程環境:

1、 使用Jbuilder
Jbuilder與EJB Container能夠進行無縫串連。Jbuilder和Inprise的應用伺服器包括了所有的開發和配置Enterprise Beans的工具以及所需要的庫:運行和管理Enterprise Bean的容器、命名服務、 事務服務、Java資料庫、開發Enterprise Beans所需要的API、一個增強java-to-iiop編譯器,支援實值型別和RMI訊號等等。
Jbuilder還提供了一個快速開發應用程式Enterprise Beans的工具和嚮導。通過簡單而且直觀的步驟,嚮導協助你建立一個Enterprise Bean。自己設定某些預設值,產生了bean的模板,在上面,我們可以增加我們自己的應用邏輯。Jbuilder也提供了一個EJB的介面產生嚮導。嚮導在Enterprise Bean的公用方法基礎上產生了Remote介面和Home介面。Jbuilder還提供一個配置器的嚮導協助我們逐步的建立XML描述器檔案。並將產生的Stubs集中到一個jar檔案中。

2、使用Jbuilder之外的Integration Environment:
如果你使用其它的除了別的Integration Environment(IDE)。要確定使用了Integration EnvironmentIDE所帶的容器工具。也要驗證IDE是否支援EJB規範的相應的版本,還要確定它是否正確的支援EJB的API。
要確定JD到所支援的EJB容器的版本。可以通過檢查Inprise的安裝說明來確定EJB容器所支援的支援JDK的版本。
在配置Enterprise Bean的時候,你必須使用Inprise的應用伺服器所提供的工具。這些工具能夠編輯和修改第三方的代理商提供的Inprise配置描述器。還能夠驗證配置描述器,能夠驗證bean的原始碼。

六、一個簡單的HELLO例子

1、安裝Apusic Application Server
Note:以下以Linux為例,來說明Apusic Application Server的安裝過程。其他平台的安裝,可參考Apusic Application Server安裝手冊。
下載JDK1.3,Apusic Application Server必須運行在jdk1.3以上環境中。可從以下網站下載最新JDK。
http://java.sun.com
下載Apusic Application Server
Apusic Application Server 試用版可從以下網址得到:
http://www.apusic.com/download/enter.jsp
在下載完成後,你可以得到一個包裹檔案apusic.zip,選定安裝目錄,假設安裝到/usr下,則用以下命令:
cd /usr
jar xvf apusic.zip
/usr下會出現一個目錄apusic,Apusic Application Server的所有程式都被解壓到/usr/apusic下。
將以下路徑加入到CLASSPATH中
/usr/apusic/lib/apusic.jar
$JAVA_HOME/lib/tools.jar
用以下命令運行Apusic Application Server
java -Xms64m com.apusic.server.Main -root /usr/apusic

2、定義EJB遠程介面(Remote Interface)
任何一個EJB都是通過Remote Interface被調用,EJB開發人員首先要在Remote Interface中定義這個EJB可以被外界調用的所有方法。執行Remote Interface的類由EJB產生工具產生。
以下是HelloBean的Remote Inteface程式:

package ejb.hello;import java.rmi.RemoteException;import java.rmi.Remote;import javax.ejb.*;public interface Hello extends EJBObject, Remote {//this method just get "Hello World" from HelloBean.public String getHello() throws RemoteException;}

3、定義Home Interface
EJB容器通過EJB的Home Interface來建立EJB執行個體,和Remote Interface一樣,執行Home Interface的類由EJB產生工具產生。
以下是HelloBean 的Home Interface程式:

package ejb.hello;import javax.ejb.*;import java.rmi.Remote;import java.rmi.RemoteException;import java.util.*;/*** This interface is extremely simple it declares only* one create method.*/public interface HelloHome extends EJBHome {public Hello create() throws CreateException,RemoteException;}

4、寫EJB類\r
在EJB類中,編程者必須給出在Remote Interface中定義的遠程方法的具體實現。EJB類中還包括一些 EJB規範中定義的必須實現的方法,這些方法都有比較統一的實現模版,編程者只需花費精力在具體業務方法的實現上。
以下是HelloBean的代碼:

package ejb.hello;import javax.ejb.*;import java.util.*;import java.rmi.*;public class HelloBean implements SessionBean {static final boolean verbose = true;private transient SessionContext ctx;// Implement the methods in the SessionBean// interfacepublic void ejbActivate() {if (verbose)System.out.println("ejbActivate called");}public void ejbRemove() {if (verbose)System.out.println("ejbRemove called");}public void ejbPassivate() {if (verbose)System.out.println("ejbPassivate called");}/*** Sets the session context.** @param SessionContext*/public void setSessionContext(SessionContext ctx) {if (verbose)System.out.println("setSessionContext called");this.ctx = ctx;}/*** This method corresponds to the create method in* the home interface HelloHome.java.* The parameter sets of the two methods are* identical. When the client calls* HelloHome.create(), the container allocates an* instance of the EJBean and calls ejbCreate().*/public void ejbCreate () {if (verbose)System.out.println("ejbCreate called");}/*** **** HERE IS THE BUSINESS LOGIC ****** the getHello just return a "Hello World" string.*/public String getHello()throws RemoteException{return("Hello World");}}

5、建立ejb-jar.xml檔案
ejb-jar.xml檔案是EJB的部署描述檔案,包含EJB的各種配置資訊,如是有狀態Bean(Stateful Bean) 還是無狀態Bean(Stateless Bean),交易類型等。ejb-jar.xml檔案的詳細資料請參閱EJB規範。以下是HelloBean的設定檔:

<?xml version="1.0"?><!DOCTYPE ejb-jar PUBLIC "-//Sun Microsystems Inc.//DTD Enterprise JavaBeans 1.2//EN" "http://java.sun.com/j2ee/dtds/ejb-jar_1_2.dtd"><ejb-jar><enterprise-beans><session><ejb-name>Hello</ejb-name><home>ejb.hello.HelloHome</home><remote>ejb.hello.Hello</remote><ejb-class>ejb.hello.HelloBean</ejb-class><session-type>Stateless</session-type><transaction-type>Container</transaction-type></session></enterprise-beans><assembly-descriptor><container-transaction><method><ejb-name>Hello</ejb-name><method-name>*</method-name></method><trans-attribute>Required</trans-attribute></container-transaction></assembly-descriptor></ejb-jar>

6、編譯和部署\r
編譯Java源檔案並將編譯後class和ejb-jar.xml打包到Hello.jar
mkdir build
mkdir build/META-INF
cp ejb-jar.xml build/META-INF
javac -d build *.java
cd build
jar cvf Hello.jar META-INF ejb
cd ..
用EJB工具產生可部署到Apusic Application Server中啟動並執行jar檔案:
java com.apusic.ejb.utils.EJBGen -d /usr/apusic/classes/Hello.jar build/Hello.jar
增加/usr/apusic/classes/Hello.jar到CLASSPATH中
將Hello.jar加入到Apusic Application Server設定檔中。在/usr/apusic/config/server.xml 加入以下幾行:

<module><ejb><ejb-uri>classes/Hello.jar</ejb-uri><bean><ejb-name>Hello</ejb-name><jndi-name>HelloHome</jndi-name></bean></ejb></module>

啟動伺服器\r
java -Xms64m com.apusic.server.Main -root /usr/apusic

7、寫用戶端調用程式\r
您可以從Java Client,JSP,Servlet或別的EJB調用HelloBean。
調用EJB有以下幾個步驟:
通過JNDI(Java Naming Directory Interface)得到EJB Home Interface
通過EJB Home Interface 建立EJB對象,並得到其Remote Interface
通過Remote Interface調用EJB方法

以下是一個從Java Client中調用HelloBean的例子:

package ejb.hello;import javax.naming.Context;import javax.naming.InitialContext;import java.util.Hashtable;import javax.ejb.*;import java.rmi.RemoteException;/*** @author Copyright (c) 2000 by Apusic, Inc. All Rights Reserved.*/public class HelloClient{public static void main(String args[]){String url = "rmi://localhost:6888";Context initCtx = null;HelloHome hellohome = null;try{Hashtable env = new Hashtable();env.put(Context.INITIAL_CONTEXT_FACTORY,"com.apusic.jndi.InitialContextFactory");env.put(Context.PROVIDER_URL, url);initCtx = new InitialContext(env);}catch(Exception e){System.out.println("Cannot get initial context: " + e.getMessage());System.exit(1);}try{hellohome = (HelloHome)initCtx.lookup("HelloHome");Hello hello = hellohome.create();String s = hello.getHello();System.out.println(s);}catch(Exception e){System.out.println(e.getMessage());System.exit(1);}}}

運行HelloClient,可得到以下輸出:
Hello World




相關文章

Beyond APAC's No.1 Cloud

19.6% IaaS Market Share in Asia Pacific - Gartner IT Service report, 2018

Learn more >

Apsara Conference 2019

The Rise of Data Intelligence, September 25th - 27th, Hangzhou, China

Learn more >

Alibaba Cloud Free Trial

Learn and experience the power of Alibaba Cloud with a free trial worth $300-1200 USD

Learn more >

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。