本文通过简单例子,描述如何利用ejb开发、部署和运行一个客户机/服务器应用。例子的客户端作为java独立应用运行,由converterclient.java类实现。它实现一个简单的实时会话,主要通过客户端应用调用服务器端ejb类converterejb.java来实现。如果你已经安装了j2ee,则可以在doc/guides/ejb/examples/converter目录中找到这些例子。
为了实现本文所描述的简单例子,你需要完成以下任务:
?编写和编译ejb程序
?创建j2ee应用
?打包ejb(.jar)
?部署j2ee应用
?编写和编译客户端程序
?运行客户端
下面章节我们将就上述工作任务以及所涉及的知识点进行简单阐述。
前提
实现本文提供例子的前提是您安装了javasoft.com或相关操作系统厂商网站下载的j2se sdk,以及安装了相应操作系统版本的j2ee sdk(www.javasoft.com下载)并进行了正确配置。关于j2se和j2ee的安装、配置和其它进一步信息,请参阅产品相关文档。
ejb编码
每个ejb程序必须要求编写下述代码:
?远程接口(remote interface )
?本地接口(home interface )
?实现组件(enterprise bean class )
远程接口编码
远程接口定义了客户端能够调用的商业方法,这些商业方法是有服务器端的企业组件实现的,本文所涉及的converter.java编码如下:
import javax.ejb.ejbobject;//引入必须的包
import java.rmi.remoteexception;
public interface converter extends ejbobject {//必须继承ejbobject类
/*定义客户端可以调用的方法*/
public double dollartoyen(double dollars) throws remoteexception;
public double yentoeuro(double yen) throws remoteexception;
}
本地接口编码
本地接口定义了员徐客户端创建、查找或移动ejb的方法,本文所涉及的本地接口类converterhome接口只定义了一个create方法,返回远程接口类型,编码如下:
import java.io.serializable;
import java.rmi.remoteexception;
import javax.ejb.createexception;
import javax.ejb.ejbhome;
public interface converterhome extends ejbhome {
converter create() throws remoteexception, createexception;
}
企业组件类(ejb)编码
本文中的企业组件(ejb)是一个无状态会话组件,命名为converterejb.java,该组件实现了两个商业方法:dollartoyen和yentoeuro,与远程接口converter所定义客户端可访问方法一致,该类编码如下:
import java.rmi.remoteexception;
import javax.ejb.sessionbean;
import javax.ejb.sessioncontext;
public class converterejb implements sessionbean {
public double dollartoyen(double dollars) {
return dollars * 121.6000;
}
public double yentoeuro(double yen) {
return yen * 0.0077;
}
public converterejb() {}
public void ejbcreate() {}
public void ejbremove() {}
public void ejbactivate() {}
public void ejbpassivate() {}
public void setsessioncontext(sessioncontext sc) {}
}
编译ejb
现在需要对上述三个类进行编译,在unix平台和nt/9x平台上的编译略有区别,分别如下编译:
unix:
1. 在下面的脚本compileejb.sh中,将该成实际j2ee安装目录。
#!/bin/sh
j2ee_home=
cpath=.:$j2ee_home/lib/j2ee.jar
javac -classpath "$cpath" converterejb.java converterhome.java converter.java
2. 运行compileejb.sh 脚本
windows:
1. 在下面的compileejb.bat批处理文件中,将 该为实际j2ee安装目录。
set j2ee_home=
set cpath=.;%j2ee_home%/lib/j2ee.jar
javac -classpath %cpath% converterejb.java converterhome.java converter.java
2. 运行批处理文件compileejb.bat。
创建j2ee应用
你不能够直接将企业组件(ejb)部署到j2ee服务器,必须将组件加到一个j2ee 应用中然后再部署。在本节,你将创建一个叫做converterapp的新j2ee应用并保存为converterapp.ear。
1. 在命令行提示符下启动j2ee服务器:
j2ee ?verbose
(停止服务器命令 j2ee -stop.)
2. 在另一个终端窗口运行部署工具:
deploytool
(按f1获取部署工具帮助)
3. 创建新的j2ee应用
a. 在部署工具中选择“文件”菜单
b. 从“文件”菜单中选择“新应用”
c. 点击浏览
d. 在文件选择框中定位存放.ear文件的目录
e. 文件命名为converterapp.ear.
f. 点击“新应用”
g. 点击“确定”
企业组件(ejb)打包
本部分你将运行部署工具的创建ejb向导来完成下述任务:
?创建组件部署描述符
?将描述符和组件类打包为.jar文件
?将ejb.jar文件打包到j2ee应用converterapp.ear 文件
从“文件”菜单中选择创建ejb来开始创建新的ejb,这个向导将显示下面的对话框:
介绍对话框:
a. 阅读向导特性说明文档
b. 点击“下一步”
ejb jar 对话框:
a. 在标有"enterprise bean will go in," 的组合框中选择converterapp.
b.在jar display name域输入converterjar,声明ejb .jar文件包含该组件,该名字会在树形应用结构中呈现。
c. 点击增加内容文本域
d. 在内容编辑对话框顶部,输入包含.class文件的目录
e. 选择该目录下相关.class加入:converter.class, converterejb.class, 和converterhome.class.
f. 点击确定
g. 点击下一步
综合对话框:
a. 在组件类型中选择“会话”
b. 选择“无状态”
b. 在ejb类组合框中选择converterejb.
c. 在本地接口组合框中选择converterhome.
d. 在远程接口组合框中选择converter.
e. 在企业组件命名域中输入converterbean.
f. 点击下一步
环境入口对话框:
因为你可以跳过后面的对话框,所以可以点击完成结束创建ejb应用任务。
部署j2ee应用
现在j2ee应用中已经包含企业组件(ejb)了,可以对其进行部署。
1.指定企业组件的jndi名字
a. 在应用部署波农工具中,在应用树形结构中选择converterapp
b. 选择jndi名字标签
c. 在jndi 名字域中,输入myconverter并确认。 客户端将使用该名字来定位本地接口。
2.部署j2ee应用
a. 从工具菜单中选择“部署”
b. 在第一个对话框中选择converterapp为部署对象,localhost为目标服务器
c. 选择标有"return client jar." 的选择框
d. 在文本域中敲入converterappclient.jar的确切目录,如j2ee的例子目录doc/guides/ejb/examples/converter
e. 点击下一步
f. 在第二个对话框中,核实converterbean 的jndi命名为myconverter.
g.点击下一步
h. 在第三个对话框中点击结束
i. 在部署进程对话框中,点击ok完成部署
开发客户端
客户端程序converterclient是一个独立运行的java应用,创建converterclient主要包括以下步骤:
1. 客户端编码
2. 客户端编译
客户端编码
converterclient.java 源码展示了ejb客户端最基本的任务实现,即:
?定位本地接口
?创建企业组件(ejb)
?调用商业方法
定位本地接口
converterhome接口定义了ejb声明周期方法如create,在中converterclient 可以调用create方法之前converterhome对象必须被实例化,包括三个步骤:
1. 创建jndi命名上下文
context initial = new initialcontext();
2. 查找与jndi命名myconverter绑定的对象
java.lang.object objref = initial.lookup("myconverter");
3. 限定指向converterhome对象的参考
converterhome home =
(converterhome) portableremoteobject.narrow(objref,
converterhome.class);
创建企业组件(ejb)实例
客户端通过调用本地接口converthome对象的create方法创建converterejb类对象, create 方法返回组件converter类型的对象。然后,远程方法定义的在converterejb实现的商业方法可以被客户端调用。当客户端调用create 方法时,ejb容器将实例化converterejb,然后调用converterejb.ejbcreate 方法。
converter currencyconverter = home.create();
调用商业方法
完成上述任务后,调用商业方法就比较简单了。你调用converter对象的方法, ejb容器将相应的调用运行在j2ee服务器中的converterejb 实例的方法。客户端调用商业方法dollartoyen的代码如下:
double amount = currencyconverter.dollartoyen(100.00);
converterclient源码
下面是converterclient.java的完整源码:
import javax.naming.context;
import javax.naming.initialcontext;
import javax.rmi.portableremoteobject;
import converter;
import converterhome;
public class converterclient {
public static void main(string[] args) {
try {
context initial = new initialcontext();
object objref = initial.lookup("myconverter");
converterhome home =
(converterhome)portableremoteobject.narrow(objref,
converterhome.class);
converter currencyconverter = home.create();
double amount = currencyconverter.dollartoyen(100.00);
system.out.println(string.valueof(amount));
amount = currencyconverter.yentoeuro(100.00);
system.out.println(string.valueof(amount));
currencyconverter.remove();
} catch (exception ex) {
system.err.println("caught an unexpected exception!");
ex.printstacktrace();
}
}
}
编译客户端代码
unix:
1. 在下面脚本compileclient.sh, 对 根据j2ee实际安装目录作相应改动。
#!/bin/sh
j2ee_home=
cpath=.:$j2ee_home/lib/j2ee.jar
javac -classpath "$cpath" converterclient.java
2. 运行脚本文件compileclient.sh
windows:
1. 在下面批处理文件compileclient.bat中,对根据实际j2ee安装目录进行修改。
set j2ee_home=
set cpath=.;%j2ee_home%/lib/j2ee.jar
javac -classpath %cpath% converterclient.java
2. 运行批处理文件compileclient.bat
运行客户端
运行客户端你需要converterappclient.jar文件,该文件包含允许客户端与ejb容器中ejb实例通信所需的存根类, converterappclient.jar 文件在部署j2ee应用过程中创建。
unix:
1. 在下面脚本testclient.sh, 对 根据j2ee实际安装目录作相应改动。
#!/bin/sh
j2ee_home=
cpath=$j2ee_home/lib/j2ee.jar:converterappclient.jar:.
java -classpath "$cpath" converterclient
2. 运行脚本文件testclient.sh
windows:
1. 在下面批处理文件testclient.bat中,对根据实际j2ee安装目录进行修改。
set j2ee_home=
set cpath=.;%j2ee_home%/lib/j2ee.jar;converterappclient.jar
java -classpath "%cpath%" converterclient
2. 运行批处理文件 testclient.bat
常见问题处理
当运行converterclient 时发现下面错误:
1. java.lang.classcastexception
可能无法找到converterappclient.jar文件。
2. java.lang.noclassdeffounderror: converterclient
无法定位converterclient.class 文件。
3. java.lang.noclassdeffounderror: javax/naming/context
无法找到所需的j2ee.jar 文件,确认classpath设置。
4. javax.naming.namenotfoundexception: lookup of name myconverter failed.
j2ee服务器无法定位jndi名字myconverter所绑定的组件。
5. javax.naming.namingexception: error accessing repository: cannot connect to orb at . . . .
j2ee服务器没有运行。
闽公网安备 35060202000074号