EJB2.0教程 详解EJB技术及实现原理(1)
http://developer.51cto.com 2009-06-11 16:25 IT技术 我要评论(0)
本文向您介绍了EJB是一个能够远程调用的javaBean.以及详细介绍了EJB2.0教程
EJB是什么呢?
EJB是一个J2EE体系中的组件.再简单的说它是一个能够远程调用的javaBean.它同普通的javaBean有两点不同.
第一点,就是远程调用.
第二点,就是事务的功能,我们在EJB中声明的事务会通过容器帮助我们来处理.支持EJB的SERVER有以下几个:
Weblogic
Webspere
Appserver
Jboss
我选用的是weblogic+JBuilder9开发.回过来我们继续说这个EJB的原理.它是分布式的.这个的意思其实很简单不需要想太复杂.就是我们把事情不是交给一个人去处理.而是把事情划分一下交给多个人处理,而多个人处理之后我们让这个分配的人来把最后得到的结合处理.
EJB我们首先要明确它是放在服务器端的组件.
一共有三种EJB
1,SessionBean 复杂处理业务逻辑的.
2,EntityBean 处理数据
3,MessageBean 消息Bean异步,耦合的处理.
那么谁能调用EJB呢?也或者说EJB被谁调用呢?我们说它就是放在server的一个能够远程调用的javaBean.所以它可以被Java的语言调用servlet,jsp等都ok的说.而且它还可以被C++语言调用.很强大吧.EJB的最基本的出发点就是推动Java在服务器端的编程能力.所以呢它的功能就我个人来看太强悍了..= =
这个远程调用是通过什么呢.Java是通过RMI-JRMP(java远程方法调用)协议来调用.EJB就是通过这个来实现的.C++是通过Corba-iiop协议来调用的.这个协议支持两端不同语言的调用.Corba是公共对象请求代理服务iiop是网络内部对象协议.
下面我们来简单说一下这个分布式的调用。客户端发送一个请求给服务器首先是传给stub代理类它发送参数给skeleton委托类然后这个类调用我们的实现类取得结果再远路返回。这样一个分布处理就结束了。后面会具体的结合代码分析。先记住这个大致的结构就好。
我们写一个EJB需要做那些工作呢?
1,写一个接口继承EJBObject 这个类作为远程接口
2,写一个接口继承EJBHome 这个类里有一个方法是create()它返回接口类型。
3,写一个Bean继承SessionBean, 这个类里包含一个create()方法和一个业务方法。
4,写一个ejb-jar.xml 这个xml是把上面的三个文件组合起来
5,写一个weblogic-ejb-jar.xml 这个xml是连接查找source的作用
上面的两个xml文件需要放在META-INF目录下。而以上这些类都需要打包在一个jar文件中然后在server部署。这样就完成了EJB的部署。例如:
import javax.ejb.*; import java.rmi.*; public interface AddCount extends EJBObject { public int addCount(int a,int b) throws RemoteException; }
AddCountHome.java这个是继承EJBHome的类.它里面包含的这个create()返回的是AddCount类型对象.
import javax.ejb.*; import java.rmi.*; public interface AddCountHome extends EJBHome { public AddCount create() throws RemoteException,CreateException; }
下面这个是我们的Bean.这个类继承了SessionBean
import javax.ejb.*; public class AddCountBean implements SessionBean { public void ejbCreate() { } public void setSessionContext(SessionContext ctx) throws EJBException, java.rmi.RemoteException { } public void ejbRemove() throws EJBException, java.rmi.RemoteException { } public void ejbActivate() throws EJBException, java.rmi.RemoteException { } public void ejbPassivate() throws EJBException, java.rmi.RemoteException { } public int addCount(double a,double b) { return a+b; } }
这个里面我们实现了业务的方法addCount(){a+b;}。同时需要指出一下它的其他方法(这些仅仅简单指出后面的教程有详细说明)。首先是ejbCreate()这个方法实际上是对我们的远程接口的实现类的初始化.setSessionContext(SessionContext ctx)设置context.容器是在这个方法之后产生的实例.
ejbRemove()毫无疑问是一个实例结束移除.ejbActivate()激活方法.它的作用是激活钝化.ejbPassivate()钝化方法.当实例的内容长时间不进行处理的时候就会钝化.也就是闲置的意思.以上这几个是SessionBean的基本方法.希望大家可以自己慢慢理解.之后也会反复说到这些的.
下面我们写xml文件
首先是ejb-jar.xml
xml version="1.0" encoding="UTF-8"?>
Enterprise JavaBeans 2.0//EN" "http://java.sun.com/dtd/ejb-jar_2_0.dtd">
<ejb-jar>
<enterprise-beans>
<session>
<display-name>firstdisplay-name>
<ejb-name>addejb-name>
<home>AddCountHomehome>
<remote>AddCountremote>
<ejb-class>AddCountBeanejb-class>
<session-type>Statelesssession-type>
<transaction-type>Containertransaction-type>
session>
enterprise-beans>
<assembly-descriptor>
<container-transaction>
<method>
<ejb-name>addejb-name>
<method-name>*method-name>
method>
<trans-attribute>Requiredtrans-attribute>
container-transaction>
assembly-descriptor>
ejb-jar>
下面这个是weblogic-ejb-jar.xml
xml version="1.0" encoding="UTF-8"?>
<weblogic-ejb-jar>
<weblogic-enterprise-bean>
<ejb-name>
add
ejb-name>
<jndi-name>rainnightjndi-name>
weblogic-enterprise-bean>
weblogic-ejb-jar>
我们接下来写测试类
import java.util.*;
import java.naming.*;
import java.rim.*;
public class AddTest{
public static void main(String bb[])throws Exception{
Hashtable hash = new Hashtable();
hash.put(Context.INITIAL_COUNTEXT_FACTORY,
"weblogic.jndi.WLInitialContextFactory");
hash.put(Context.PROVIDER_URL,
"t3://localhost:7001");
Object obj = context.lookup("rainnight");
AddCountHome home = (AddCountHome)PortableRemoteObject(obj,AddCountHome.class);
AddCount local = home.create();
System.out.println(local.add(1,1));
}
}
测试类的hash是初始化我们的weblogic的xml信息.这里的t3://localhost:7001是weblogic的特殊协议指向的是ip位置.然后lookup("rainnight")查找jndi,而实际上也就是通过这个jndi找到我们的ejb组件.通过得到的对象我们对比一下是不是Home类型.然后我们执行home.create()产生AddCount的实例.最后调用方法就ok了.
下面是如何执行这个的方法.
第一步,jdk,weblogic.需要快些下载安装啦..
第二步,配置环境变量.基本的java的环境变量如何配置我就不说了.
这里需要特别指出要把java目录下的lib中的tools.jar加载到我们的class_path中.
然后我们再把weblogic的目录下的server目录下的lib中的weblogic.jar找到也加载进来.
这样我们编译需要的东西就ok了.
第三步,编译java类.
第四步,打包.jar cvf AddCount.jar *.class META-INF/*.xml
第五步,java weblogic.appc AddCount.jar
第六步,部署到weblogic中.
第七步,运行Test类.
分享到:
相关推荐
1. **接口与实现分离** - EJB2.0强调接口的使用,使得组件更加灵活且易于测试。业务接口定义了业务方法,而远程接口允许客户端调用这些方法。 2. **生命周期管理** - 容器负责Bean的创建、初始化、激活、钝化、销毁...
**企业级JavaBeans(EJB)2.0详解** 企业级JavaBeans(Enterprise JavaBeans,简称EJB)是Java平台上用于构建分布式企业级应用的重要组件模型。EJB 2.0是这一技术的一个重要版本,它在EJB 1.1的基础上进行了许多...
**企业级JavaBeans(EJB)2.0详解——基于Helloworld示例** EJB(Enterprise JavaBeans)是Java EE(Java Platform, Enterprise Edition)平台的核心组成部分,它为开发分布式、事务处理、安全和可扩展的企业级应用...
提供的"www.pudn.com.txt"可能包含了更多关于EJB 2.0的链接或参考资源,可以结合"EJB2.0.pdf"文档深入学习。理解并掌握EJB 2.0的实体Bean对于理解企业级Java应用的架构和设计原则至关重要。随着技术的发展,虽然EJB ...
**企业级JavaBeans(EJB)2.0详解** 企业级JavaBeans(EJB)是Java平台上用于构建可部署在企业级服务器上的分布式、组件化的应用程序的重要技术。EJB 2.0是其一个重要的版本,它在1.1的基础上进行了多方面的改进和...
在这个"使用ejb2.0 ql教程代码"中,我们将会探讨EJB 2.0中的查询语言(QL)及其在实际应用中的使用。 EJB QL(Enterprise JavaBeans Query Language)是EJB 2.0引入的一种面向对象的查询语言,它允许开发者根据对象...
【标题】:WebSphere 6与EJB 2.0详解 【描述】:WebSphere 6是一个由IBM推出的强大企业级应用服务器,它支持Java Enterprise Edition(JEE)规范,其中包括EJB 2.0(Enterprise JavaBeans 2.0)。EJB 2.0是Java平台...
### SPRING2.0开发详解 #### 一、Spring框架简介 Spring框架是一个开源的Java平台,用于构建企业级应用程序和服务。它最初由Rod Johnson在2004年创建,并随着时间的发展不断壮大和完善。Spring 2.0版本是Spring...
**企业级JavaBeans(EJB)2.1详解** 企业级JavaBeans(EJB)是Java平台上用于构建可部署在企业级服务器上的组件模型。EJB 2.1是其第二个主要版本,发布于2003年,是Java EE(Java Platform, Enterprise Edition)的...
全书以剖析EJB 2.0的技术核心以及开发与部署的过程为中心,共分3大部分20章,包括无状态会话Bean、有状态会话Bean、CMP实体Bean、EJB QL语言、集成RMI-IIOP与JNDI、应用客户端开发、EJB部署、持久化EJB与CORBA的集成...
### EJB技术详解 #### EJB 2.0与EJB 1.1的主要区别及其应用场景 EJB(Enterprise JavaBeans)技术自1998年首次推出以来,经历了多个版本的演进,其中EJB 2.0是EJB 1.1的重要升级版,带来了诸多改进和新特性,旨在...
1. **EJB2.0与EJB1.1的区别** - EJB2.0引入了更丰富的组件模型,包括Session Beans(会话bean)、Entity Beans(实体bean)和Message-Driven Beans(消息驱动bean),并且提供了更强的事务管理和安全特性。 - EJB...
本书详细介绍了J2EE框架的重要组成部分——EJB及其相关技术。全书以剖柏EJB 2.0的技术核心以及开发与部署的过程为中心,共分3部分20章,包括无状态会话Bean、有状态会话Bean等。
### EJB完整配置过程详解 #### 一、WebLogic服务器安装与配置 1. **WebLogic服务器安装**: - 打开`D:\bea\wlserver_10.0\common\bin`目录下的`config.cmd`或在Linux平台上运行`config.sh`。 - 在选择JDK时,请...
EJB2.0支持使用JMS进行消息传递,从而实现异步通信和事件驱动的应用程序设计模式。 以上内容覆盖了EJB技术的核心知识点,包括EJB的基本概念、不同类型的EJB组件以及如何编写、部署和测试EJB程序。希望这些知识点...
1. **服务器(Server)**:EJB服务器负责管理和协调EJB容器,同时提供对操作系统服务及Java相关服务的访问,如通过JNDI(Java Naming and Directory Interface)访问命名空间和基于OTSI(Object Transaction Service ...
**企业级JavaBeans(EJB)技术详解** 企业级JavaBeans(Enterprise JavaBeans,简称EJB)是Java平台上用于构建可扩展、安全且事务处理能力强的企业级应用的核心组件。EJB自1999年发布以来,已经成为Java企业级开发...