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. public interface AddCount extends EJBObject
  4. {
  5. public int addCount(int a,int b) throws RemoteException;
  6. }

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

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

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

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

这个里面我们实现了业务的方法 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. assembly-descriptor > 
  24. 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. < jndi-name > rainnight jndi-name > 
  8. weblogic-enterprise-bean > 
  9. 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. }
  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类.

时间: 2024-08-30 13:21:17

EJB2.0教程 详解EJB技术及实现原理的相关文章

使用ssh开发rest web服务支持http etag header的教程详解

原创整理不易,转载请注明出处:使用ssh开发rest web服务支持http etag header的教程详解 代码下载地址:http://www.zuidaima.com/share/1777391667989504.htm 导言 REST方式的应用程序构架在近日所产生的巨大影响突出了Web应用程序的优雅设计的重要性.现在人们开始理解"WWW架构"内在的可测量性及弹性,并且已经开始探索使用其范例的更好的方式.在本文中,我们将讨论一个Web应用开发工具--"简陋的.卑下的&q

CentOS 7上安装Zabbix Server 3.0 图文详解

转载自 http://www.linuxidc.com/Linux/2016-09/135204.htm CentOS 7上安装Zabbix Server 3.0 图文详解 1.查看系统信息. cat /etc/RedHat-releaseCentOS Linux release 7.0.1406 (Core) uname -a Linux VM_96_155_centos3.10.0-123.el7.x86_64 #1 SMP Mon Jun 30 12:09:22 UTC 2014 x86_

实例详解 EJB 中的六大事务传播属性--转

前言 事务 (Transaction) 是访问并可能更新数据库中各种数据项的一个程序执行单元 (unit).在关系数据库中,一个事务可以是一条或一组 SQL 语句,甚至整个程序.它有通常被称为 ACID 的原子性(Atomicity).一致性(Consistency).隔离性(Isolation).持续性(Durability)四大特性: 原子性(Atomicity):一个事务是一个不可分割的工作单位,事务中包括的诸操作要么都做,要么都不做. 一致性(Consistency):事务必须是使数据库

[转载]AxureRP 7.0部件详解(一)

本文为Axure RT7.0教程,本章主要介绍menu菜单.table表格.Tree Widget 树部件三个部件,后续将持续更新...... Menu 菜单 常用案例 网站导航菜单部件通常用于母板之中,其目的是在原型中跳转到不同页面. 编辑菜单要编辑菜单,右键点击在弹出的上下文菜单中选择 在之前/之后新增菜单项.删除菜单.新增子菜单. 菜单样式使用工具栏或部件样式面板可以编辑菜单样式,如填充颜色,字体颜色,字体大小等,需要注意的是子菜单是通过父菜单获取格式的.要自定义菜单样式,参见 弹出菜单案

SAE上传web应用(包括使用数据库)教程详解及问题解惑

转自:http://blog.csdn.net/baiyuliang2013/article/details/24725995 SAE上传web应用(包括使用数据库)教程详解及问题解惑:       最近由于工作需求,需利用SAE平台,但在使用过程中遇到不少问题,比如如何上传应用,上传应用完毕后打不开,mysql连接不上等等,以及云豆的计费问题,结合个人使用心得,将在本帖一一解答.       1,上传web应用首先,使用SAE平台需要注册自己的账号吧,这个就不说了,然后进入我的首页,会看到: 

超轻量级DI容器框架Google Guice与Spring框架的区别教程详解及其demo代码片段分享

原创不易,转载请注明出处:超轻量级DI容器框架Google Guice与Spring框架的区别教程详解及其demo代码片段分享 代码下载地址:http://www.zuidaima.com/share/1759689106541568.htm 依赖注入,DI(Dependency Injection),它的作用自然不必多说,提及DI容器,例如spring,picoContainer,EJB容器等等,近日,google诞生了更轻巧的DI容器--Guice! 废话不多讲了,先看看Guice是如何实现

apache2.2虚拟主机配置教程详解

apache2.2虚拟主机配置教程详解 一.修改httpd.conf 打开appserv的安装目录,找到httpd.conf文件,分别去掉下面两行文字前面的#号. #LoadModule vhost_alias_module modules/mod_vhost_alias.so 去掉#意思是启用apache的虚拟主机功能. #Include conf/extra/httpd-vhosts.conf 去掉这一行的#意思是从conf/extra/httpd-vhosts.conf这个文件导入虚拟主机

windows上安装Anaconda和python的教程详解

一提到数字图像处理编程,可能大多数人就会想到matlab,但matlab也有自身的缺点: 1.不开源,价格贵 2.软件容量大.一般3G以上,高版本甚至达5G以上. 3.只能做研究,不易转化成软件. 因此,我们这里使用Python这个脚本语言来进行数字图像处理. 要使用Python,必须先安装python,一般是2.7版本以上,不管是在windows系统,还是Linux系统,安装都是非常简单的. 要使用python进行各种开发和科学计算,还需要安装对应的包.这和matlab非常相似,只是matla

Windows系统下nodejs、npm、express的下载和安装教程详解

这篇文章主要介绍了Windows系统下nodejs.npm.express的下载和安装教程详解,非常不错,具有参考借鉴价值,需要的朋友可以参考下1. node.js下载 首先进入http://nodejs.org/dist/,这里面的版本呢,几乎每个月都出几个新的,建议大家下载最新版本,看看自己的电脑是多少位的,别下错了. 下载完解压到你想放的位置就好了,解压后你会发现里面有node.exe.我解压到了D:\software_install婴儿起名http://www.bbqmw.net/qm_