在JBoss访问EJB,如果包含EJB的jar,JBoss访问EJB和要通过local接口访问EJB的war不被打包成一个ear来部署,会遇到问题。
如果你的war中包含了EJB的local接口的class,那么war在通过jndi取得EJB的引用试图将其转化成接口类型时会抛 ClassCastException。而如果war中不包含local接口的class,则会抛class not found的异常。这都是由讨厌的classloader问题导致的。每个放到JBoss的deploy目录里的部署单元都有自己的独立的 classloader树,这两棵树在jvm的classloader里是平级的。
如果war和EJB jar里都包含了某个EJB的local接口的class时,那么同一个类就分别存在于两棵classloader树中。通过jndi取得的引用的类型是 EJB jar中的local接口的类型,将其转化成war里的那个local接口类型时就出错了,因为它们不是同一个类。
而classloader是不能访问同级的其他的classloader下的类的,所以如果war里不包含接口的class,有会因找不到class而出错。
JBoss访问EJB这种时候就是使用ear的时候,位于同一个ear里EJB jar的classloader是war的classloader的父classloader。
这样,只需要部署一份接口类,war也能访问到它,因为子 classloader能访问父classloader载入的类。
【编辑推荐】