我正在使用 JEE6 堆栈,包括 JPA 2.0、JSF 2.0、EJB 3.1 等。
我的架构设置方式如下:
我使用 hibernate 作为我的 JPA 提供程序,使用 JPA 注释 DAO。我有与我的 facelet/xhtml 页面相对应的 JSF 托管 bean。我有处理所有数据库请求的 EJB。
我的 XHTML 页面有 JSF EL,它调用我的托管 bean。我的托管 bean 包含对由 EJB 管理的 DAO 实体的引用。例如,我有一个映射到数据库表的用户实体。我有一个用户 EJB,它处理所有返回用户的 CRUD 操作。我有一个编辑用户的页面。高级工作流是:导航到用户编辑页面 -> EL 调用位于托管 bean 中的加载用户的方法。该方法从 EJB 调用 userEJB.loadUser(user) 以从数据库中获取用户。用户被编辑并提交 -> 在托管 bean 中调用一个函数,该 bean 调用 EJB 中的一个函数来保存用户。等等
我在使用 EJB 访问我的 JSF 页面中的数据时遇到问题。我在延迟初始化错误方面遇到了很多问题,我相信这是由于我的设置方式造成的。
例如,我有一个客户端实体,它有一个延迟加载的用户列表。为了得到一个客户端,我在我的 EJB 中调用一个方法,该方法进入数据库,找到一个客户端并返回它。稍后我希望访问此客户端用户列表,为此我必须通过调用某种方法返回 EJB 以加载这些用户(因为它们是延迟加载的)。这意味着我必须创建一个方法,例如
public List<User> getUserListByClient(Client c)
{
c = em.merge(c); return c.getUserList();
}
这种方法的唯一目的是加载用户(我什至不肯定这种方法是好的或有效的)。如果我自己在做会话管理,我只想让会话对整个请求保持打开状态并直接访问属性,这很好,因为会话无论如何都会打开,EJB 中似乎有这一额外的间接层这对我来说很困难。
我确实喜欢 EJB,因为我喜欢它们由容器控制、池化、免费提供事务管理等这一事实。但是,我觉得我使用它们不正确,或者我的 JSF 应用程序设置不正确。
任何反馈将不胜感激。
谢谢,