public class MyComponentImpl implements MyComponent {
public String myMethod(...) {
...
}
...
}
最后是無狀態Session Bean自身:
public class MyComponentEJB implements extends AbstractStatelessSessionBean
implements MyComponent {
MyComponent _myComp;
/**
* Obtain our POJO service object from the BeanFactory/ApplicationContext
* @see org.springframework.ejb.support.AbstractStatelessSessionBean#onEjbCreate()
*/
protected void onEjbCreate() throws CreateException {
_myComp = (MyComponent) getBeanFactory().getBean(
ServicesConstants.CONTEXT_MYCOMP_ID);
}
// for business method, delegate to POJO service impl.
public String myMethod(...) {
return _myComp.myMethod(...);
}
...
}
Spring為支持EJB而提供的這些基類默認情況下會創建并載入一個BeanFactory (這個例子里,它是ApplicationContext的子類),作為其生命周期的一部分, 供EJB使用(比如像上面的代碼那樣用來獲取POJO服務對象)。載入的工作是通過 一個策略對象完成的,它是BeanFactoryLocator的子類。 默認情況下,實際使用的BeanFactoryLocator的實現類是 ContextJndiBeanFactoryLocator,它根據一個JNDI環境變量 來創建一個ApplicationContext對象(這里是EJB類,路徑是 java:comp/env/ejb/BeanFactoryPath)。如果需要改變 BeanFactory或ApplicationContext的載入策略,我們可以在子類中重定義了的 setSessionContext()方法或具體EJB子類的構造函數中調用 setBeanFactoryLocator()方法來改變默認使用的 BeanFactoryLocator實現類。具體細節請參考JavaDoc。
如JavaDoc中所述,有狀態Session Bean在其生命周期中可能會被鈍化并重新激活, 如果是不可序列化的BeanFactory或ApplicationContext,由于它們不會被EJB容器保存, 所以還需要手動在ejbPassivate和ejbActivate 這兩個方法中分別調用unloadBeanFactory()和loadBeanFactory, 才能在鈍化或激活的時候卸載或載入。
有些情況下,要載入ApplicationContext以使用EJB組件, ContextJndiBeanFactoryLocator的默認實現基本上足夠了, 不過,當ApplicationContext需要載入多個bean,或這些bean初始化所需的時間或內存 很多的時候(例如Hibernate的SessionFactory的初始化),就有可能出問題,因為 每個EJB組件都有自己的副本。這種情況下,用戶會想重載 ContextJndiBeanFactoryLocator的默認實現,并使用其它 BeanFactoryLocator的變體,例如ContextSingleton 或者BeanFactoryLocator,他們可以載入并共享一個 BeanFactory或ApplicationContext來為多個EJB組件或其它客戶端所公用。這樣做 相當簡單,只需要給EJB添加類似于如下的代碼:
文章來源于領測軟件測試網 http://www.kjueaiud.com/