EJB輕松進(jìn)階之一
文章來源:硅谷動(dòng)力 作者:中流砥柱
一、引言
EJB(Enterprise JavaBeans)是Java程序設(shè)計(jì)中比較高級(jí)的內(nèi)容,也是Java程序員由入門級(jí)向高手級(jí)前進(jìn)的門檻。SUN公司認(rèn)證Java程序員(SCJP)與SUN公司認(rèn)證Java開發(fā)員(SCJD)之間的一個(gè)顯著區(qū)別就是:SCJP不考EJB,而SCJD要考。隨著越來越多的企業(yè)采用J2EE平臺(tái)開發(fā)電子商務(wù)應(yīng)用系統(tǒng),EJB開發(fā)已成為今天的Java程序員必須要面對(duì)的問題。
本文首先以一個(gè)例程介紹了一般分布式對(duì)象應(yīng)用程序的基本原理,然后從基本的下載、安裝、配置開始,逐步介紹EJB程序編程的方法,從而使EJB的學(xué)習(xí)成為一件輕松而有趣的事情。
二、典型的分布式對(duì)象程序
不管是CORBA還是RMI,其實(shí)現(xiàn)分布式對(duì)象的策略都是相似的,我們可以用一個(gè)簡(jiǎn)單的程序例子來模擬一個(gè)分布式對(duì)象程序的構(gòu)成。
這個(gè)例子模擬了一個(gè)遠(yuǎn)程請(qǐng)求對(duì)象屬性的過程。有一個(gè)遠(yuǎn)程對(duì)象Dog在網(wǎng)絡(luò)上,現(xiàn)在要得到它的名字(strName)屬性。程序在客戶端設(shè)一個(gè)存根(Dog_Stub)類,在服務(wù)器端啟動(dòng)一個(gè)骨架(dog_Skeleton)類,這兩個(gè)類都實(shí)現(xiàn)了Dog接口,Dog_Stub與Dog_Skeleton通過Socket進(jìn)行遠(yuǎn)程通信。當(dāng)客戶程序DogClient向Dog_Stub發(fā)出獲取名字屬性的請(qǐng)求時(shí),Dog_Stub對(duì)象把方法名“getName()”作為一個(gè)字符串通過Socket發(fā)給遠(yuǎn)程的Dog_Skeleton對(duì)象,Dog_Skeleton對(duì)象收到這個(gè)字符串后再根據(jù)字符串的內(nèi)容執(zhí)行DogServer對(duì)象的getName()方法,得到Dog的名字,然后又通過Socket返回給DogStub對(duì)象。整個(gè)流程通過網(wǎng)絡(luò)實(shí)現(xiàn),但對(duì)于客戶程序DogClient來講,它并不知道真正的Dog對(duì)象在哪里,甚至也不知道這個(gè)過程通過了網(wǎng)絡(luò),它只知道發(fā)出的獲取名字屬性的請(qǐng)求得到了滿意的結(jié)果而已。
事實(shí)上,CORBA或Java RMI的實(shí)現(xiàn)方式與此類似,只不過遠(yuǎn)沒有這么簡(jiǎn)單而已。這個(gè)程序?qū)τ谡f明分布式對(duì)象應(yīng)用程序的執(zhí)行機(jī)理是很有用的。
程序源代碼如下所示:
文件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 */
運(yùn)行該分布式對(duì)象程序時(shí),首先運(yùn)行DogServer,然后在客戶端運(yùn)行DogClient即可看到結(jié)果。
上一篇:Java經(jīng)驗(yàn)點(diǎn)滴:類注釋文檔編寫方法
欄 目:Java編程
下一篇:跟我學(xué)Java Swing之游戲設(shè)計(jì)(2)
本文標(biāo)題:EJB輕松進(jìn)階之一
本文地址:http://www.jygsgssxh.com/a1/Javabiancheng/8550.html
您可能感興趣的文章


閱讀排行
- 1C語言 while語句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹的示例代碼(圣誕
- 3利用C語言實(shí)現(xiàn)“百馬百擔(dān)”問題方法
- 4C語言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 01-10Java咖啡館(1)——嘆咖啡
- 01-10JVM的垃圾回收機(jī)制詳解和調(diào)優(yōu)
- 01-10Java Socket編程(三) 服務(wù)器Sockets
- 01-10Java進(jìn)階:Struts多模塊的技巧
- 01-10J2SE 1.5版本的新特性一覽
- 01-10Java Socket編程(一) Socket傳輸模式
- 01-10Java運(yùn)行時(shí)多態(tài)性的實(shí)現(xiàn)
- 01-10Java Socket編程(二) Java面向連接的類
- 01-10Java Socket編程(四) 重復(fù)和并發(fā)服務(wù)
- 01-10Java經(jīng)驗(yàn)點(diǎn)滴:處理沒有被捕獲的異常
隨機(jī)閱讀
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 04-02jquery與jsp,用jquery
- 01-10使用C語言求解撲克牌的順子及n個(gè)骰子
- 01-10delphi制作wav文件的方法
- 01-10C#中split用法實(shí)例總結(jié)
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 01-11ajax實(shí)現(xiàn)頁面的局部加載
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置


