EJB轻松进阶之一

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

一、引言

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

(0)

相关推荐

  • EJB轻松进阶之一

    文章来源:硅谷动力 作者:中流砥柱 一.引言 EJB(Enterprise JavaBeans)是Java程序设计中比较高级的内容,也是Java程序员由入门级向高手级前进的门槛.SUN公司认证Java程序员(SCJP)与SUN公司认证Java开发员(SCJD)之间的一个显著区别就是:SCJP不考EJB,而SCJD要考.随着越来越多的企业采用J2EE平台开发电子商务应用系统,EJB开发已成为今天的Java程序员必须要面对的问题. 本文首先以一个例程介绍了一般分布式对象应用程序的基本原理,然后从基本

  • C++图文并茂轻松进阶面向对象

    目录 一.进阶面向对象(上) 二.小结(上) 三.进阶面向对象(下) 四.小结(下) 一.进阶面向对象(上) 面向对象的意义在于 将日常生活中习惯的思维方式引入程序设计中 将需求中的概念直观的映射到解决方案中 以模块为中心构建可复用的软件系统 提高软件产品的可维护性和可扩展性 类和对象是面向对象中的两个基本概念 类∶指的是一类事物,是一个抽象的概念 对象∶指的是属于某个类的具体实体 类是一种模型,这种模型可以创建出不同的对象实体 对象实体是类模型的一个具体实例 注:一个类可以有很多对象,而一个对

  • Python序列操作之进阶篇

    简介 Python 的序列(sequence)通常指一个可迭代的容器,容器中可以存放任意类型的元素.列表和元组这两种数据类型是最常被用到的序列,python内建序列有六种,除了刚刚有说过的两种类型之外,还有字符串.Unicode字符串.buffer对像和最后一种xrange对像,这几种都是不常使用的.本文讲解了列表推导式.切片命名.列表元素排序.列表元素分组的使用方法.学习了 Python 基本的列表操作后,学习这些进阶的操作,让我们写出的代码更加优雅简洁和 pythonic . 列表推导式 当

  • Nodejs爬虫进阶教程之异步并发控制

    之前写了个现在看来很不完美的小爬虫,很多地方没有处理好,比如说在知乎点开一个问题的时候,它的所有回答并不是全部加载好了的,当你拉到回答的尾部时,点击加载更多,回答才会再加载一部分,所以说如果直接发送一个问题的请求链接,取得的页面是不完整的.还有就是我们通过发送链接下载图片的时候,是一张一张来下的,如果图片数量太多的话,真的是下到你睡完觉它还在下,而且我们用nodejs写的爬虫,却竟然没有用到nodejs最牛逼的异步并发的特性,太浪费了啊. 思路 这次的的爬虫是上次那个的升级版,不过呢,上次那个虽

  • Nodejs进阶:基于express+multer的文件上传实例

    概览 图片上传是web开发中经常用到的功能,node社区在这方面也有了相对完善的支持. 常用的开源组件有multer.formidable等,借助这两个开源组件,可以轻松搞定图片上传. 本文主要讲解以下内容,后续章节会对技术实现细节进行深入挖掘. 基础例子:借助express.multer实现单图.多图上传. 常用API:获取上传的图片的信息. 进阶使用:自定义保存的图片路径.名称. 环境初始化 非常简单,一行命令. npm install express multer multer --sav

  • 轻松建立Web服务器

    "我想有个家,一个不需要华丽的地方--",对于想建网上家园的你来说是否对这首歌更有一番感触?装了宽带之后,我们完全可以把自己的电脑作成Web服务器,感受一下拥有几十GB空间,CGI.PHP.ASP等都支持的网上豪宅.心急喝不了热粥,呵呵,首先还是来简单了解一下有关Web服务的基础知识. 基础篇 Web服务器:在网络中为实现信息发布.资料查询.数据处理等诸多应用搭建基本平台的服务器. Web服务器如何工作:在Web页面处理中大致可分为三个步骤,第一步,Web浏览器向一个特定的服务器发出W

  • Java内存映射 大文件轻松处理

    前言 内存映射文件(Memory-mapped File),指的是将一段虚拟内存逐字节映射于一个文件,使得应用程序处理文件如同访问主内存(但在真正使用到这些数据前却不会消耗物理内存,也不会有读写磁盘的操作),这要比直接文件读写快几个数量级. 稍微解释一下虚拟内存(很明显,不是物理内存),它是计算机系统内存管理的一种技术.像施了妖法一样使得应用程序认为它拥有连续的可用的内存,实际上呢,它通常是被分隔成多个物理内存的碎片,还有部分暂时存储在外部磁盘存储器上,在需要时进行数据交换. 内存映射文件主要的

  • Python进阶之迭代器与迭代器切片教程

    在前两篇关于 Python 切片的文章中,我们学习了切片的基础用法.高级用法.使用误区,以及自定义对象如何实现切片用法(相关链接见文末).本文是切片系列的第三篇,主要内容是迭代器切片. 迭代器是 Python 中独特的一种高级特性,而切片也是一种高级特性,两者相结合,会产生什么样的结果呢? 1.迭代与迭代器 首先,有几个基本概念要澄清:迭代.可迭代对象.迭代器. 迭代 是一种遍历容器类型对象(例如字符串.列表.字典等等)的方式,例如,我们说迭代一个字符串"abc",指的就是从左往右依次

  • python进阶从青铜到王者一定会用上的Python技巧

    目录 1.如何判断一个列表中的数值是否全部小于某个数 2.如何对列表中的字符串按照特定要求进行排序 3.如何实现按照键或者数值对字典进行排序 4.怎么将列表中的数字转换成字符串 5.如何判断列表中的元素是否都属于一个类型 6.列表怎么反转呢 7.如何从可迭代对象中随机选择一个元素 9.筛选出以元音字母开头的字符串 10.创建一个计数字典的方法 每个案例都有两种解决方法,第一种方法相对小白,第二种方法则是属于有经验的高手写法. 下面有请青铜和王者两位选手进场.各位同学请对号入座~ 1.如何判断一个

  • JAVA进阶之HashMap底层实现解析

    首先我们来通过下面的图看看JDK1.7时代的HashMap是如何通过数组+链表的形式进行值储存的. 由图中的描述可以清楚地看出来,当数组第一次被定义并且第一次被赋值的时候,这个时候的操作很简单,就是将这个值赋值到我们的table数组上面去.这个操作完成以后,然后我们进行二次put: 如图左下角描述所示的情况,当数组table下标出现了相等的情况的时候,此时此刻还是将肝铁侠2的值赋值给tablle[i]的,这里讲述的是JDK1.7版本下HashMap中插入的头插法,而JDK1.8版本中是用的尾插法

随机推荐