服务热线:13616026886

技术文档 欢迎使用技术文档,我们为你提供从新手到专业开发者的所有资源,你也可以通过它日益精进

位置:首页 > 技术文档 > JAVA > 新手入门 > 基础入门 > 查看文档

ejb入门文章


  一.enterprise beans
  在ejb(enterprise java beans)中定义了两种不同类别的enterprise bean :
  *会话 bean (session bean)
  *实体bean (entity bean)
  
  1. 会话 bean (session bean)
  会话 bean 是调用它的客户端代码要完成的工作。当客户端与服务器建立联系,那么一个会话 bean 就建立起来了。根据会话 bean 的状态不同有分为:
  a. 状态会话 bean (stateful session bean)
  b. 无状态会话 bean (stateless session bean)
  1.1 状态会话 bean (stateful session bean)
  当客户机和服务器建立连接之后,状态会话 bean (stateful session bean) 将一直在客户机和服务器之间保持着用户的某个状态。例如:用户使用银行的atm时,经过验证之后,用户可以连续执行多次操作,在这个过程当中,用户的合法状态将一直被保留,直到她将信用卡取出,结束这次操作。这时,状态会话 bean (stateful session bean) 也就被销毁。
  1.2无状态会话 bean (stateless session bean)
  当客户机和服务器建立连接之后,无状态会话 bean (stateless session bean)处理单一的用户请求或商务过程。无状态会话 bean (stateless session bean)不需要从以前的请求中提取任何状态。例如,用户的用户密码确认。用户输入密码后,发送请求。组件返回真或假来确认用户,一旦过程完成,无状态会话 bean (stateless session bean) 也宣告结束。
  2. 实体bean (entity bean)
  实体bean (entity bean)只是数据模型,它不包括商务逻辑。实体bean (entity bean)可以将关系/对象数据库的数据映射到内存中供其它组件使用。实体bean (entity bean)是一直存在的,而且具有很高的容错性能。实体bean (entity bean)能供允许多用户同时访问。
  
  二. 会话 bean (session bean)
  ejb的执行过程是被放在一个ejb容器中进行的,所以客户端不会直接调用我们写好的enterprise bean ,而是调用ejb容器生成的一个ejbobject (ejb对象)来实现。那么,我们在编写服务器端的enterprise bean 时,就要考虑这点。既然客户端不能直接访问,就由ejbobject来代劳,所以在编写服务器端时,就要编写服务器端的一个接口(remote)用来与客户机联系,实力化ejbobject。要生成ejbobject 就要调有home 接口,来建立这个实力。
  
  以下是会话 bean 的代码分析:
  a.enterprise bean 类:sailorsy.class
  1.setsessioncontext(sessioncontext ctx)方法
  它是ejb容器和enterprise bean互相作用的关口。
  
  import java.rmi.*;
  import javax.ejb.*;
  public class sailorsy implements sessionbean{
  private sessioncontext ctx=null;
  public voic setsessioncontext(sessioncontext ctx){
  this.ctx=ctx;
  }//setsessioncontext
  }//class sailorsy
  
  2.ejbcreate(…)方法
  它可以初始化enterprise bean ,可以定义不同的ejbcreate(…)方法,每个方法所带的参数不同。但是,必许要存在至少一种。
  
   import java.rmi.*;
   import javax.ejb.*;
  public class sailorsy implements sessionbean{
  private sessioncontext ctx=null;
  public voic setsessioncontext(sessioncontext ctx){
  this.ctx=ctx;
  }//setsessioncontext
      public void ejbcreate() {
      }//ejbcreate
  }//class sailorsy
  
  3.ejbpassivate()方法
  如果初始化的enterprise bean 过多,ejb容器将其中的一些挂起(passivate),释放他们所占用的空间。
  
   import java.rmi.*;
   import javax.ejb.*;
  public class sailorsy implements sessionbean{
  private sessioncontext ctx=null;
  
  public voic setsessioncontext(sessioncontext ctx){
  this.ctx=ctx;
  }//setsessioncontext
  
      public void ejbcreate() {
      }//ejbcreate
      public void ejbpassivate() {
      }//ejbpassivate
  
  }//class sailorsy
  
  4.ejbactivate()方法
  和ejbpassivate正好相反,它将被挂起的bean从新调回。
  
  import java.rmi.*;
   import javax.ejb.*;
  public class sailorsy implements sessionbean{
  private sessioncontext ctx=null;
  
  public voic setsessioncontext(sessioncontext ctx){
  this.ctx=ctx;
  }//setsessioncontext
  
      public void ejbcreate() {
      }//ejbcreate
      public void ejbpassivate() {
      }//ejbpassivate
      
      public void ejbactivate() {
      }//ejbactivate
  
  }//class sailorsy
  
  5.ejbremove()方法
  它可以清除ejb容器中的bean。
  
   import java.rmi.*;
   import javax.ejb.*;
  public class sailorsy implements sessionbean{
  private sessioncontext ctx=null;
  
  public voic setsessioncontext(sessioncontext ctx){
  this.ctx=ctx;
  }//setsessioncontext
  
      public void ejbcreate() {
      }//ejbcreate
  
      public void ejbpassivate() {
      }//ejbpassivate
      
      public void ejbactivate() {
      }//ejbactivate
  
      public void ejbremove() {
      }//ejbremove
     
       public string showname(){
       return "hello,my name is sailorsy";
      }//自己的商务方法
  }//class sailorsy
  
  以上这些是ejb必需的回调方法,我们可以在里面加入自己的方法,加入自己的商务逻辑。
  b.home 接口: sailorsyhome
  
    import java.rmi.*;
  import javax.ejb.*;
  
  public interface sailorsyhome extends ejbhome {
   public sailorsyremote create() throws remoteexception, createexception;
  }
  
  c. remote接口:sailorsyremote
  import java.rmi.*;
  import javax.ejb.*;
  
  public interface sailorsyremote extends ejbobject {
   public java.lang.string showname() throws remoteexception;
  }
  
  三.调用会话 bean:sailorsytestclient1
   [code]    import javax.naming.*;
  import javax.ejb.*;
  import javax.rmi.portableremoteobject;
  import java.rmi.*;
  
  public class sailorsytestclient1 {
   private sailorsyhome sailorsyhomeobject = null;
  
   //construct the ejb test client
   public sailorsytestclient1() {
    try {
     //以下是客户端使用jndi定位home对象。
     context ctx = new initialcontext();
  
     //look up jndi name
     object ref = ctx.lookup("sailorsy");
  
     //cast to home interface
     sailorsyhomeobject = (sailorsyhome) portableremoteobject.narrow(ref, sailorsyhome.class);
  
    }
    catch(exception e) {
     e.printstacktrace();
    }
   }
  
   //----------------------------------------------------------------------------
   // utility methods
   //----------------------------------------------------------------------------
  
   public sailorsyhome gethome() {
    return sailorsyhomeobject;
   }
   //main method
  
   public static void main(string[] args) throws exception{
    sailorsytestclient1 client = new sailorsytestclient1();
    sailorsyremote sr=client.gethome() .create()
    string s=sr.showname()
    system.out.print(s);
    // use the gethome() method of the client object to call home interface
    // methods that will return a remote interface reference. then
    // use that remote interface reference to access the ejb.
   }
  }[/code]
  
  以上的ejb在win2000+jbuilder5/jbuilder6+bas4.5经过测试。
  
  以下是整个ejb的执行过程:
  1. 客户端通过jndi检索home对象的引用;
  2. jndi返回home对象的引用;
  3. 请求创建一个新的ejb对象;
  4. 创建ejb对象;
  5. 返回ejb对象;
  6. 调用商务方法;
  7. 调用enterprise bean.

扫描关注微信公众号