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

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了EJB2.0教程 详解EJB技术及实现原理相关的知识,希望对你有一定的参考价值。

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的部署。例如:

  1. import javax.ejb.*;  
  2. import java.rmi.*;  
  3.  
  4. public interface AddCount extends EJBObject  
  5. {  
  6.         public int addCount(int a,int b) throws RemoteException;  

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

  1. import javax.ejb.*;  
  2. import java.rmi.*;  
  3.  
  4. public interface AddCountHome extends EJBHome  
  5. {  
  6.         public AddCount create() throws RemoteException,CreateException;  

 

 

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

  1. import javax.ejb.*;  
  2.  
  3. public class AddCountBean implements SessionBean  
  4. {  
  5.         public void ejbCreate()  
  6.         {  
  7.         }  
  8.         public void setSessionContext(SessionContext ctx)  
  9.                        throws EJBException,  
  10.                               java.rmi.RemoteException  
  11.         {  
  12.         }  
  13.         public void ejbRemove()  
  14.                throws EJBException,  
  15.                       java.rmi.RemoteException  
  16.         {  
  17.         }  
  18.  
  19.         public void ejbActivate()  
  20.                  throws EJBException,  
  21.                         java.rmi.RemoteException  
  22.         {  
  23.         }  
  24.         public void ejbPassivate()  
  25.                   throws EJBException,  
  26.                          java.rmi.RemoteException  
  27.         {  
  28.         }  
  29.         public int addCount(double a,double b)  
  30.         {  
  31.                 return a+b;  
  32.         }  

 

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

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

下面我们写xml文件
首先是ejb-jar.xml

 

 
  1. xml   version = "1.0"   encoding = "UTF-8" ?>  
  2. Enterprise JavaBeans 2.0//EN" "http://java.sun.com/dtd/ejb-jar_2_0.dtd"  
  3. ejb-jar  
  4.      enterprise-beans  
  5.          session  
  6.              display-name first display-name  
  7.              ejb-name add ejb-name  
  8.              home AddCountHome home  
  9.              remote AddCount remote  
  10.              ejb-class AddCountBean ejb-class  
  11.              session-type Stateless session-type  
  12.              transaction-type Container transaction-type       
  13.          session  
  14.      enterprise-beans  
  15.      assembly-descriptor  
  16.          container-transaction  
  17.              method  
  18.                  ejb-name add ejb-name  
  19.                  method-name method-name  
  20.              method  
  21.              trans-attribute Required trans-attribute  
  22.          container-transaction  
  23.           
  24.      assembly-descriptor  
  25. ejb-jar  

下面这个是weblogic-ejb-jar.xml

  1. xml   version = "1.0"   encoding = "UTF-8" ?> 
  2. weblogic-ejb-jar  
  3.      weblogic-enterprise-bean  
  4.          ejb-name  
  5.                 add    
  6.                  ejb-name  
  7.           
  8.          jndi-name rainnight jndi-name  
  9.      weblogic-enterprise-bean  
  10. weblogic-ejb-jar  

 

我们接下来写测试类

 
  1. import java.util.*;  
  2. import java.naming.*;  
  3. import java.rim.*;  
  4. public class AddTest{  
  5.         public static void main(String bb[])throws Exception{  
  6.                 Hashtable  hash  =  new  Hashtable();  
  7.                 hash.put(Context.INITIAL_COUNTEXT_FACTORY,  
  8.                                 "weblogic.jndi.WLInitialContextFactory");  
  9.                 hash.put(Context.PROVIDER_URL,  
  10.                                 "t3://localhost:7001");  
  11.                 Object  obj  =  context .lookup("rainnight");  
  12.                 AddCountHome  home = (AddCountHome)PortableRemoteObject(obj,AddCountHome.class);  
  13.                 AddCount  local  =  home .create();  
  14.                 System.out.println(local.add(1,1));  
  15.         }  

 

测试类的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类.

以上是关于EJB2.0教程 详解EJB技术及实现原理的主要内容,如果未能解决你的问题,请参考以下文章

EJB2.0 ejb-jar.xml配置文件详解

EJB2.0版本的HelloWorld

雷林鹏分享:EJB教程

雷林鹏分享:EJB教程

如何使用独立程序访问 EJB 2.0

EJB框架 详细介绍和注解的使用