JSF CDI:会话范围bean 最佳实践

我目前正在学习JSF 2.0,我很高兴这个会话范围function的存在,这对于在同一页面上打开新选项卡或新窗口并拥有单独的资源非常有用,而不是相互覆盖。

但我很好奇如何以一种好的方式实现这一点,关于何时开始对话以及何时关闭它。

在我的例子中,我为每个JSF页面都有每个CDI bean。 让我们说我有一个菜单,当它被点击时,这将导致页面A,并且从A,可能导致B,B可能导致C,C可能导致D,所有这4个页面都连接在一起链。

可以从B或C或D bean访问A的bean属性,也可以从C或D bean等访问B的属性。

现在我很困惑:

  • 是否所有这些ABCD都应该在对话范围内,或者只是A? 因为我认为有时来自ABCD链之外的另一个页面,就像页面F一样,它可以导航到页面B,尽管我还不知道如何将数据提供给bean B.
  • 是否应将所有这些ABCD组合成一个bean
  • 何时何地开始对话,我在考虑构造函数,但我不认为这是一个好主意,因为我更喜欢在第一次访问页面时启动对话,而不是bean
  • 何时何地停止谈话,以便不会闲置未使用的资源

请分享您对此的看法。

JSF 2提供了请求,视图,会话和应用程序范围。 CDI引入了Conversation范围,但更重要的是,它引入了一个标准,通过该标准可以将新范围添加到平台。

您描述的范围可能更适合窗口范围之类的自定义范围。 实现此范围的两个项目是:

  1. Apache MyFaces CODI
  2. IceFaces有一个JSF(非CDI) 窗口范围实现 。

不过,我鼓励你重新思考你的bean结构。 我自己非常喜欢View范围,再加上JSF 2视图参数,可以将信息从一个页面传播到另一个页面(以及从一个View范围实例传播到另一个页面)。

MyFaces“View Access”范围看起来像是另一种简洁的方法,只要您浏览的页面保持对该范围的引用,bean就会保留在范围内。