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的作用
(不同的server会是不同的。这里选用的是weblogic)
上面的两个xml文件需要放在META-INF目录下。
而以上这些类都需要打包在一个jar文件中然后在server部署。
这样就完成了EJB的部署
例如:
我们写个简单的计算吧。
(先声明下吧本教程的说明都是我自己的理解,
也许并不是一些文档上的描述那么正规但是很方便理解的。
如果有实在无法苟同的地方大家多多包含。这是为了便于理解的讲解)
AddCount.java这个就是我们继承EJBObject的类.
- 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"?>
- <!DOCTYPE ejb-jar PUBLIC "-//Sun Microsystems, Inc.//DTD Enterprise JavaBeans 2.0//EN" "http://java.sun.com/dtd/ejb-jar_2_0.dtd">
- <ejb-jar>
- <enterprise-beans>
- <session>
- <display-name>first</display-name>
- <ejb-name>add</ejb-name>
- <home>AddCountHome</home>
- <remote>AddCount</remote>
- <ejb-class>AddCountBean</ejb-class>
- <session-type>Stateless</session-type>
- <transaction-type>Container</transaction-type>
- </session>
- </enterprise-beans>
- <assembly-descriptor>
- <container-transaction>
- <method>
- <ejb-name>add</ejb-name>
- <method-name>*</method-name>
- </method>
- <trans-attribute>Required</trans-attribute>
- </container-transaction>
- </assembly-descriptor>
- </ejb-jar>
- 下面这个是weblogic-ejb-jar.xml
- <?xml version="1.0" encoding="UTF-8"?>
- <!DOCTYPE weblogic-ejb-jar PUBLIC '-//BEA Systems, Inc.//DTD WebLogic 8.1.0 EJB//EN' 'http://www.bea.com/servers/wls810/dtd/weblogic-ejb-jar.dtd'>
- <weblogic-ejb-jar>
- <weblogic-enterprise-bean>
- <ejb-name>
- add
- </ejb-name>
- <jndi-name>rainnight</jndi-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类.