一、引言
EJB(Enterprise JavaBeans)是Java程序設計中比較高級的內容,也是Java程序員由入門級向高手級前進的門檻。SUN公司認證Java程序員(SCJP)與SUN公司認證Java開發員(SCJD)之間的一個顯著區別就是:SCJP不考EJB,而SCJD要考。隨著越來越多的企業采用J2EE平臺開發電子商務應用系統,EJB開發已成為今天的Java程序員必須要面對的問題。
本文首先以一個例程介紹了一般分布式對象應用程序的基本原理,然后從基本的下載、安裝、配置開始,逐步介紹EJB程序編程的方法,從而使EJB的學習成為一件輕松而有趣的事情。
二、典型的分布式對象程序
不管是CORBA還是RMI,其實現分布式對象的策略都是相似的,我們可以用一個簡單的程序例子來模擬一個分布式對象程序的構成。
這個例子模擬了一個遠程請求對象屬性的過程。有一個遠程對象Dog在網絡上,現在要得到它的名字(strName)屬性。程序在客戶端設一個存根(Dog_Stub)類,在服務器端啟動一個骨架(dog_Skeleton)類,這兩個類都實現了Dog接口,Dog_Stub與Dog_Skeleton通過Socket進行遠程通信。當客戶程序DogClient向Dog_Stub發出獲取名字屬性的請求時,Dog_Stub對象把方法名“getName()”作為一個字符串通過Socket發給遠程的Dog_Skeleton對象,Dog_Skeleton對象收到這個字符串后再根據字符串的內容執行DogServer對象的getName()方法,得到Dog的名字,然后又通過Socket返回給DogStub對象。整個流程通過網絡實現,但對于客戶程序DogClient來講,它并不知道真正的Dog對象在哪里,甚至也不知道這個過程通過了網絡,它只知道發出的獲取名字屬性的請求得到了滿意的結果而已。
事實上,CORBA或Java RMI的實現方式與此類似,只不過遠沒有這么簡單而已。這個程序對于說明分布式對象應用程序的執行機理是很有用的。
程序源代碼如下所示:
文件Dog.java
public interface Dog
{
public String getName() throws Exception;
}/* Dog */
文件DogClient.java
public class DogClient
{
public static void main( String[] args ) throws Exception
{
Dog dog = new Dog_Stub();
String strName = dog.getName();
System.out.println( "姓名:" + strName );
}//main()
}/* DogClient */
文件DogServer.java
public class DogServer implements Dog
{
String strName;
int intAge;
public String getName() throws Exception
{
return strName;
}//getName()
public DogServer( String strNameInput )
{
strName = strNameInput;
}//DogServer()
public static void main( String[] args ) throws Exception
{
New Dog_Skeleton( new DogServer( "TOMCAT" ) );
}//main()
}/* DogServer */
文件Dog_Skeleton.java
import java.io.*;
import java.net.*;
public class Dog_Skeleton extends Thread
{
static ServerSocket ss = null;
DogServer ds;
public Dog_Skeleton( DogServer dsInput ) throws Exception
{
ds = dsInput;
if ( ss == null )
ss = new ServerSocket( 8000 );
this.start();
}//Dog_Skeleton()
public synchronized void run()
{
Try
{
while ( ss != null )
{
Socket socket = ss.accept();
ObjectInputStream ois = new ObjectInputStream( socket.getInputStream() );
ObjectOutputStream oos = new ObjectOutputStream( socket.getOutputStream() );
String strMethodName = ( String )ois.readObject();
if ( strMethodName.equals( "getName()" ) )
oos.writeObject( ds.getName() );
oos.flush();
ois.close();
oos.close();
socket.close();
}//while
}//try
catch( Exception e )
{
e.printStackTrace();
}//catch
}//run()
}/* Dog_Skeleton */
文件Dog_Stub.java
import java.io.*;
import java.net.*;
Public class Dog_Stub implements Dog
{
Socket socket;
ObjectOutputStream oos;
ObjectInputStream ois;
public Dog_Stub() throws Exception
{
socket = new Socket( "wudi", 8000 );
Oos = new ObjectOutputStream( socket.getOutputStream() );
Ois = new ObjectInputStream( socket.getInputStream() );
}//Dog_Stub()
public String getName() throws Exception
{
Oos.writeObject( "getName()" );
Oos.flush();
return ( String )ois.readObject();
}//getName()
}/* Dog_Stub */
運行該分布式對象程序時,首先運行DogServer,然后在客戶端運行DogClient即可看到結果。
新聞熱點
疑難解答