循速渐进学用Session Bean(四)

1/5/2008来源:Java教程人气:8755

session Bean要求、限制和许可

  在EJB规范中,对Session Bean有一些限制和要求。这些限制会指出哪些是bean必须做的,哪些是不能做的,以及bean必须实现的一些方法和接口。也有一些规范指出哪些处理是答应做的,这是为了避免你以为这些处理是被其它限制禁止的。

  实现SessionBean接口

  session bean必须实现javax.ejb.SessionBean接口

   声明该类为Public,而不是Final或者Abstract

   要记住EJB容器需要创建bean实例,因此该类必须是public,而且不是抽象的。

  创建一个Pubic,无参数的构造器

   同样,由于EJB容器必须创建bean的实例。假如构造器是PRotected或者private,容器就不能创建实例。

  不要实现finalize方法

   虽然你很少需要定义一个finalize方法,不过EJB规范中还是明文禁止在session和entity bean中定义finalize方法。假如你的bean需要做任何清除的操作,它们应该在ejbRemove或者ejbPassivate方法中进行。

  实现create方法和所有的remote方法

  一个session bean必须实现Home接口中指定的全部create方法,以及Remote接口中指定的全部方法。在实现这些方法时,有一些额外的要求:

  . 这些方法必须是public,而不能是static或者final

  . 参数和返回的类型必须是有效的RMI/IIOP返回类型。在通常的情况下,这意味着必须是原有的类型(int, char, double等),可串行化的对象或者Remote接口。

  . 方法名不能以ejb开头(这将令EJB的配置工具感到迷惑,并且可能带来冲突)

  可选择的实现Remote接口

  对于一个bean可以实现Remote接口,这个特性也是挺重要的。在实现类中,其中的方法签名必须和Reomote接口中的一样,除了一点,就是实现类中的方法并不抛出RemoteException。也就是说,虽然对于Remote接口的每个方法,在实现类中都必须要有相应的方法对应,而且不需要作如下的声明:

  public class ShoppingCartImpl implements SessionBean, ShoppingCart

  实现Remote接口的原因是:在漏掉一个方法时编译器将会告诉你,也就是说,假如没有实现Remote接口中的一个方法,编译器将会产生一个错误。否则,你将不知道漏掉了一个方法,直到你运行一个配置工具或者是打包工具为止。越迟发现错误,就要花越长的时间来改正它。

  在实现Remote接口时,可能会碰到的问题是使用this要害字来传送对象,而不是使用session context中的getEJBObject方法。通常,当使用this而不是getEJBObject时,编译器将会产生一个错误,因为它期待一个实现Remote接口的对象,而实现类却这样做。通过实现Remote接口,你通过了编译,但是你在运行时又碰到了错误,这是由于与EJB容器期待的不同,实现类并不是一个到Remote接口的正确引用。

  提示

  虽然实现Remote接口可以指出在编译时的错误,但是这样也会导致出现一些直到运行时才会发现的错误,令修改起来很费时间。所以你最好不要实现Remote接口,而在配置时发现一些错误。进入讨论组讨论。

  实现SessionSynchronization接口

  SessionSynchronization接口可以令一个session bean更好地控制一个事务是如何发生。

  在必要时扩展其它类

  你的实现类也可以是其它类的子类。实际上,该超类也可以是另一类bean的实现类。

  在必要时实现Helper方法

  一个实现类可能还有额外的helper方法,这些方法并不是Remote或者Home接口的一部分。对于这些方法的参数类型、返回值类型和可见性(public, protected, private)是没有限制的。

  不要抛出RemoteException

  假如需要抛出一个和EJB有关的异常,抛出javax.ejb.EJBException代替。

  Remote和Home接口的限制

  除了对实现类有限制外,对于Remote和Home接口也有一些限制。这些限制大部分和实现类类似。

  Remote接口必须扩展javax.ejb.EJBObject

  当你使用一些配置工具时,例如WebLogic提供的工具,你将会发现它会自动知道哪个类包含有Remote接口。它寻找EJBObject接口来检测到Remote接口。还有EJBObject接口包含有每个EJB都必须实现的一些方法。

  Home接口必须扩展javax.ejb.EJBHome

  和Remote接口必须扩展EJBObject一样,EJBHome接口帮助标识Home接口,并且定义了一些你可以在每个Home接口上调用的方法。

  参数和返回类型必须符合RMI/IIOP

  这意味着它们必须是原始类型、可串行化对象或者Remote接口。

  所有的方法必须抛出java.rmi.RemoteException

  由于Home和Remote接口扩展java.rmi.Remote接口,所以接口的全部方法都必须抛出java.rmi.RemoteException。RMI规范明确规定在Remote接口的所有方法都必须抛出RemoteException。

  所有的方法都必须有相应的实现

  在一个典型的RMI实现中,这一点是毫无疑问的,这是由于实现类将会实现Remote接口。但是对于EJB,由于实现类并不需要实现Home和Remote接口,对于实现类和Home及Remote接口的关系,编译器并没有一个强制的规定。

  对于Home接口的每个create方法,在实现类中都必须有一个相应的ejbCreate方法。还有,create方法抛出CreateException。

  扩展其它的接口

  要支持Enterprise JavaBeans的子类,Home和Remote接口可以扩展其它的接口,只要父接口是扩展EJBObject(对于Remote接口)或者EJBHome(对于Home接口)。进入讨论组讨论。