EJB轻松进阶之一

 更新时间:2006年12月23日 00:00:00   作者:  
(福利推荐:【腾讯云】服务器最新限时优惠活动,云服务器1核2G仅99元/年、2核4G仅768元/3年,立即抢购>>>:9i0i.cn/qcloud

(福利推荐:你还在原价购买阿里云服务器?现在阿里云0.8折限时抢购活动来啦!4核8G企业云服务器仅2998元/3年,立即抢购>>>:9i0i.cn/aliyun

文章来源:硅谷动力 作者:中流砥柱

一、引言

  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即可看到结果。

相关文章

  • java 定时同步数据的任务优化

    java 定时同步数据的任务优化

    这篇文章主要介绍了java 定时同步数据的任务优化,帮助大家更好的理解和使用Java,感兴趣的朋友可以了解下
    2020-12-12
  • 详解Swagger接口文档和常用注解的使用

    详解Swagger接口文档和常用注解的使用

    Swagger是一款遵循?Restful?风格的接口文档开发神器,支持基于?API?自动生成接口文档。本文将为大家讲讲Swagger接口文档和常用注解的使用方法,需要的可以参考一下
    2022-08-08
  • 日历显示读出输入的年月的java代码

    日历显示读出输入的年月的java代码

    这篇文章主要介绍了日历显示读出输入的年月的java代码,有需要的朋友可以参考一下
    2013-12-12
  • SpringBoot项目打jar包与war包的详细步骤

    SpringBoot项目打jar包与war包的详细步骤

    SpringBoot和我们之前学习的web应用程序不一样,其本质上是一个 Java应用程序,那么又如何部署呢?这篇文章主要给大家介绍了关于SpringBoot项目打jar包与war包的详细步骤,需要的朋友可以参考下
    2023-02-02
  • Java并发编程之闭锁与栅栏的实现

    Java并发编程之闭锁与栅栏的实现

    这篇文章主要介绍了Java并发编程之闭锁与栅栏的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-04-04
  • Java中List<T>和List<?>的区别详解

    Java中List<T>和List<?>的区别详解

    这篇文章主要介绍了Java中List<T>和List<?>的区别详解。文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • SpringBoot手写自定义starter源码

    SpringBoot手写自定义starter源码

    这篇文章主要介绍了SpringBoot手写自定义starter源码,SpringBoot拥有很多方便使用的starter,比如spring-boot-starter-log4j、mybatis-spring-boot-starter.jar等,各自都代表了一个相对完整的功能模块,需要的朋友可以参考下
    2023-10-10
  • 基于list stream: reduce的使用实例

    基于list stream: reduce的使用实例

    这篇文章主要介绍了list stream: reduce的使用实例,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-09-09
  • 常用输入字节流InputStream介绍

    常用输入字节流InputStream介绍

    下面小编就为大家带来一篇常用输入字节流InputStream介绍。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-08-08
  • spring?controller层引用service报空指针异常nullpointExceptio问题

    spring?controller层引用service报空指针异常nullpointExceptio问题

    这篇文章主要介绍了spring?controller层引用service报空指针异常nullpointExceptio问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-02-02

最新评论

?


http://www.vxiaotou.com