您的位置:首页 > 其它

EJB2.0教程 详解EJB技术及实现原理

2013-05-07 22:56 1281 查看
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的部署。例如:

[code]importjavax.ejb.*;
importjava.rmi.*;

publicinterfaceAddCountextendsEJBObject
{
publicintaddCount(inta,intb)throwsRemoteException;
}

AddCountHome.java这个是继承EJBHome的类.它里面包含的这个create()返回的是AddCount类型对象.

[code]importjavax.ejb.*;
importjava.rmi.*;

publicinterfaceAddCountHomeextendsEJBHome
{
publicAddCountcreate()throwsRemoteException,CreateException;
}

下面这个是我们的Bean.这个类继承了SessionBean

[code]importjavax.ejb.*;

publicclassAddCountBeanimplementsSessionBean
{
publicvoidejbCreate()
{
}
publicvoidsetSessionContext(SessionContextctx)
throwsEJBException,
java.rmi.RemoteException
{
}
publicvoidejbRemove()
throwsEJBException,
java.rmi.RemoteException
{
}

publicvoidejbActivate()
throwsEJBException,
java.rmi.RemoteException
{
}
publicvoidejbPassivate()
throwsEJBException,
java.rmi.RemoteException
{
}
publicintaddCount(doublea,doubleb)
{
returna+b;
}
}

这个里面我们实现了业务的方法addCount(){a+b;}。同时需要指出一下它的其他方法(这些仅仅简单指出后面的教程有详细说明)。首先是ejbCreate()这个方法实际上是对我们的远程接口的实现类的初始化.setSessionContext(SessionContextctx)设置context.容器是在这个方法之后产生的实例.

ejbRemove()毫无疑问是一个实例结束移除.ejbActivate()激活方法.它的作用是激活钝化.ejbPassivate()钝化方法.当实例的内容长时间不进行处理的时候就会钝化.也就是闲置的意思.以上这几个是SessionBean的基本方法.希望大家可以自己慢慢理解.之后也会反复说到这些的.

下面我们写xml文件

首先是ejb-jar.xml



xmlversion="1.0"encoding="UTF-8"?>

EnterpriseJavaBeans2.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

xmlversion="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>

我们接下来写测试类



importjava.util.*;
importjava.naming.*;
importjava.rim.*;
publicclassAddTest{
publicstaticvoidmain(Stringbb[])throwsException{

Hashtablehash=newHashtable();

hash.put(Context.INITIAL_COUNTEXT_FACTORY,

"weblogic.jndi.WLInitialContextFactory");

hash.put(Context.PROVIDER_URL,
"t3://localhost:7001");
Objectobj=context.lookup("rainnight");

AddCountHomehome=(AddCountHome)PortableRemoteObject(obj,AddCountHome.class);

AddCountlocal=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类.

第四步,打包.jarcvfAddCount.jar*.classMETA-INF/*.xml

第五步,javaweblogic.appcAddCount.jar

第六步,部署到weblogic中.

第七步,运行Test类.
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: