`
kuyuyingzi
  • 浏览: 53633 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

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. importjavax.ejb.*;
  2. importjava.rmi.*;
  3. publicinterfaceAddCountextendsEJBObject
  4. {
  5. publicintaddCount(inta,intb)throwsRemoteException;
  6. }

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

  1. importjavax.ejb.*;
  2. importjava.rmi.*;
  3. publicinterfaceAddCountHomeextendsEJBHome
  4. {
  5. publicAddCountcreate()throwsRemoteException,CreateException;
  6. }

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

  1. importjavax.ejb.*;
  2. publicclassAddCountBeanimplementsSessionBean
  3. {
  4. publicvoidejbCreate()
  5. {
  6. }
  7. publicvoidsetSessionContext(SessionContextctx)
  8. throwsEJBException,
  9. java.rmi.RemoteException
  10. {
  11. }
  12. publicvoidejbRemove()
  13. throwsEJBException,
  14. java.rmi.RemoteException
  15. {
  16. }
  17. publicvoidejbActivate()
  18. throwsEJBException,
  19. java.rmi.RemoteException
  20. {
  21. }
  22. publicvoidejbPassivate()
  23. throwsEJBException,
  24. java.rmi.RemoteException
  25. {
  26. }
  27. publicintaddCount(doublea,doubleb)
  28. {
  29. returna+b;
  30. }
  31. }

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

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

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


  1. xmlversion="1.0"encoding="UTF-8"?>
  2. EnterpriseJavaBeans2.0//EN""http://java.sun.com/dtd/ejb-jar_2_0.dtd">
  3. <ejb-jar>
  4. <enterprise-beans>
  5. <session>
  6. <display-name>firstdisplay-name>
  7. <ejb-name>addejb-name>
  8. <home>AddCountHomehome>
  9. <remote>AddCountremote>
  10. <ejb-class>AddCountBeanejb-class>
  11. <session-type>Statelesssession-type>
  12. <transaction-type>Containertransaction-type>
  13. session>
  14. enterprise-beans>
  15. <assembly-descriptor>
  16. <container-transaction>
  17. <method>
  18. <ejb-name>addejb-name>
  19. <method-name>*method-name>
  20. method>
  21. <trans-attribute>Requiredtrans-attribute>
  22. container-transaction>
  23. assembly-descriptor>
  24. ejb-jar>

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

  1. xmlversion="1.0"encoding="UTF-8"?>
  2. <weblogic-ejb-jar>
  3. <weblogic-enterprise-bean>
  4. <ejb-name>
  5. add
  6. ejb-name>
  7. <jndi-name>rainnightjndi-name>
  8. weblogic-enterprise-bean>
  9. weblogic-ejb-jar>

我们接下来写测试类


  1. importjava.util.*;
  2. importjava.naming.*;
  3. importjava.rim.*;
  4. publicclassAddTest{
  5. publicstaticvoidmain(Stringbb[])throwsException{
  6. Hashtablehash=newHashtable();
  7. hash.put(Context.INITIAL_COUNTEXT_FACTORY,
  8. "weblogic.jndi.WLInitialContextFactory");
  9. hash.put(Context.PROVIDER_URL,
  10. "t3://localhost:7001");
  11. Objectobj=context.lookup("rainnight");
  12. AddCountHomehome=(AddCountHome)PortableRemoteObject(obj,AddCountHome.class);
  13. AddCountlocal=home.create();
  14. System.out.println(local.add(1,1));
  15. }
  16. }

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

分享到:
评论

相关推荐

    EJB应用开发详解+书中源码

    全书以剖析EJB 2.0的技术核心以及开发与部署的过程为中心,共分3大部分20章,包括无状态会话Bean、有状态会话Bean、CMP实体Bean、EJB QL语言、集成RMI-IIOP与JNDI、应用客户端开发、EJB部署、持久化EJB与CORBA的集成...

    EJB应用开发详解配套光盘

    本书详细介绍了J2EE框架的重要组成部分——EJB及其相关技术。全书以剖柏EJB 2.0的技术核心以及开发与部署的过程为中心,共分3部分20章,包括无状态会话Bean、有状态会话Bean等。

    J2EE应用开发详解

    209 11.7.2 基于Bean管理的事务 210 11.8 EJB拦截器 212 11.9 EJB定时服务 214 11.10 EJB安全管理 214 11.11 小结 216 第12章 RMI 217 12.1 RMI简介 217 12.1.1 RMI的架构 218 12.1.2 RMI的组成及实现 218 12.1.3 ...

    基于JPQL实现纯SQL语句方法详解

    基于首次在EJB2.0中引入的EJB查询语言(EJB QL),Java持久化查询语言(JPQL)是一种可移植的查询语言,旨在以面向对象表达式语言的表达式,将SQL语法和简单查询语义绑定在一起·使用这种语言编写的查询是可移植的,可以...

    Spring 2.0 开发参考手册

    3.3.3. bean属性及构造器参数详解 3.3.4. 使用depends-on 3.3.5. 延迟初始化bean 3.3.6. 自动装配(autowire)协作者 3.3.7. 依赖检查 3.3.8. 方法注入 3.4. bean的作用域 3.4.1. Singleton作用域 3.4.2. ...

    高级Java软件架构师学习计划

    主要介绍做为一名java软件架构师都需要掌握哪些技能 Java语法与编程基础 面向对象程序设计与编码 ...JavaME相关技术手机游戏开发 建模语言详解 企业级EJB讲解 综合项目实战 架构师与项目经理素质拓展

    Spring API

    2. Spring 2.0和 2.5的新特性 2.1. 简介 2.2. 控制反转(IoC)容器 2.2.1. 新的bean作用域 2.2.2. 更简单的XML配置 2.2.3. 可扩展的XML编写 2.2.4. Annotation(注解)驱动配置 2.2.5. 在classpath中自动搜索组件...

    spring chm文档

    3.3.3. bean属性及构造器参数详解 3.3.4. 使用depends-on 3.3.5. 延迟初始化bean 3.3.6. 自动装配(autowire)协作者 3.3.7. 依赖检查 3.3.8. 方法注入 3.4. bean的作用域 3.4.1. Singleton作用域 3.4.2. ...

    Spring中文帮助文档

    3.2. 基本原理 - 容器和bean 3.2.1. 容器 3.2.2. 实例化容器 3.2.3. 多种bean 3.2.4. 使用容器 3.3. 依赖 3.3.1. 注入依赖 3.3.2. 依赖配置详解 3.3.3. 使用depends-on 3.3.4. 延迟初始化bean 3.3.5. 自动...

    Spring-Reference_zh_CN(Spring中文参考手册)

    3.3.3. bean属性及构造器参数详解 3.3.3.1. 直接量(基本类型、Strings类型等。) 3.3.3.2. 引用其它的bean(协作者) 3.3.3.3. 内部bean 3.3.3.4. 集合 3.3.3.5. Nulls 3.3.3.6. XML-based configuration metadata ...

    整理后java开发全套达内学习笔记(含练习)

    implements (关键字) 实现 ['implimәnt] import (关键字) 引入(进口,输入) Info n.信息 (information [,infә'meiʃәn] ) Inheritance [java] 继承 [in'heritәns] (遗传,遗产) initialize 预置 初始化 [i'ni...

    iuhyiuhkjh908u0980

    ant配置文件实例详解 build.xml 代码 xml version="1.0" encoding="UTF-8"?&gt; &lt;!-- name:对应工程的名字;default:需要的缺省任务(运行"ant"不指明任务时执行的任务) --&gt; by duzn 2007-04-02 回复 (0) Antenna与j2me...

    Spring 2.5 jar 所有开发包及完整文档及项目开发实例

    13) spring-mock.jar需spring-core.jar,spring-beans.jar,spring-dao.jar,spring-context.jar,spring-jdbc.jarspring2.0和spring2.5及以上版本的jar包区别Spring 2.5的Jar打包 在Spring 2.5中, Spring Web MVC...

    Maven权威指南 很精典的学习教程,比ANT更好用

    通过Maven Profiles实现可移植性 11.2.1. 覆盖一个项目对象模型 11.3. 激活Profile 11.3.1. 激活配置 11.3.2. 通过属性缺失激活 11.4. 外部Profile 11.5. Settings Profile 11.5.1. 全局Settings ...

Global site tag (gtag.js) - Google Analytics