- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这更像是一个一般性问题,以便我更好地了解 JSF 和托管 bean。因此,当人们拥有多个托管 bean 时,仅仅是因为他们想将具有相同作用域(RequestScoped、ApplicationScoped、SessionScope ...)的方法组合在一起吗?还是有其他原因?如果将具有不同范围的托管 bean 注入(inject)到另一个托管 bean 中会发生什么?以及他们为什么要将一个具有不同作用域的 bean 注入(inject)到另一个 bean,我是否可以根据需要从 JSF 访问不同的 bean,而不是将一个 bean 注入(inject)到另一个?
最佳答案
So when people having multiple managed bean, is it solely because they want to group methods with the same scoped(RequestScoped, ApplicationScoped, SessionScope...) together? Or is there some other reason?
这取决于 bean 持有的数据和 bean 的职责。如果它包含请求范围内的数据(例如表单输入值和表单操作),那么该 bean 应该进入请求范围。如果它包含 session 范围内的数据(例如登录用户、特定于用户的设置,如语言环境等),那么该 bean 应该进入 session 范围。如果它包含应用程序范围的数据(例如下拉值和其他应用程序范围的常量),那么该 bean 应该进入应用程序范围。这在逻辑上是有道理的。
What would happen if you inject managed bean with different scope into another?
您只能在另一个 bean 中注入(inject)相同或更广泛范围的 bean。例如。请求、 session 或应用程序范围的 bean 可以注入(inject)到请求范围的 bean 中。 JSF 只是将其设置为目标 bean 的属性。这没有副作用。当您尝试在另一个 bean 中注入(inject)范围较窄的 bean 时,JSF 已经会出错。您不能在 session 范围的 bean 中注入(inject)请求范围的 bean。这是完全有道理的。在同一个 session 中可以有多个请求范围的 bean,JSF 应该选择哪一个?
and why would they want to inject one bean with different scope to another, can I not just from JSF access different bean base on my need instead of inject one bean to another?
它只会添加讨厌的样板代码。为什么不让 JSF 透明地处理它呢?您无需亲自接管 JSF 的职责。注入(inject)很便宜,即使您在特定用例中不需要注入(inject)的 bean,也不会造成伤害。
关于java - 为什么要有多个托管 bean?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3347560/
我会尝试尽可能详细地描述我的问题,但如果需要更详细的解释,请告诉我。 为了简化,假设我有 3 个 DLL(实际上我有更多,但我猜这不是很重要): managed-1.dll - 托管 DLL(用 C#
我有一个 Tomcat 6 JSF Web 应用程序,我想使用 CDI bean 来设置它。不过,我必须逐渐将项目转换为 CDI。 我的问题是:CDI bean 和传统的 JSF 托管 bean 可以
我计划将 Web 应用程序从使用 JSF 托管 Bean 转换为使用 CDI 托管 Bean。我知道我需要执行以下操作: 在 WEB-INF 中添加一个空 beans.xml 文件。 将所有 JSF
我在裸域上运行我的解析应用程序。 Parse 并没有让我的生活变得轻松。 起初我很难设置它,因为大多数 DNS 托管服务不允许根域上的 CNAME,而 Parse 需要 CNAME。 决定尝试使用 C
如果您使用 Firebase 托管 将请求定向到 云函数 通过重写,“通过”托管的请求流量是否会记入 Firebase 托管 国标转出 ? (忽略 Cloud Function 的计费) 换句话说,
关闭。这个问题是off-topic .它目前不接受答案。 想改善这个问题吗? Update the question所以它是 on-topic对于堆栈溢出。 9年前关闭。 Improve this q
我有一个特定的用例,我正尝试使用 Firebase 托管来解决,它如下: 我正在使用 Gridsome 生成静态网站 在构建之前,Gridsome 使用 Graphql 并从 Headless CMS
您好,我有一个blazor页面,我想在其中显示一个变量。 这个变量从另一个线程(通过Websocket接收数据的另一个线程)获取更新,我想以线程安全的方式显示它: Blazor页面 @page "/n
我想使用 Firebase 托管来托管一个 angular 应用程序,我需要创建一个重定向到另一个 URL 中的一些旧文件。 根据 Firebase 文档,您可以进行基本重定向 "redirects"
我正在尝试找出满足电子学习平台以下要求的最佳方法。 我在其中编辑视频的后端,以便可以将它们彼此链接(例如youtube-comment函数) 用户只能在访问平台时观看视频(不允许下载!) 视频只能通过
已关闭。这个问题是 not about programming or software development 。目前不接受答案。 这个问题似乎不是关于 a specific programming
我想这是一个相当深入的主题,因此任何带有洞察信息的网址也很乐意接受。我一直在使用原生 DirectX,但从未管理过。另一方面,大多数情况下,在开发不需要高级 GPU 渲染的其他类型的应用程序时,我通常
我刚刚将一个网站部署到 Firebase 托管,效果非常好 - 设置非常简单。 但是,我的问题是,有什么方法可以使访问该网站受到身份验证的限制吗?这是一个管理面板,只有我的团队才能访问。有什么方法可以
已关闭。这个问题是 not about programming or software development 。目前不接受答案。 这个问题似乎不是关于 a specific programming
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找书籍、工具、软件库、教程或其他场外资源的问题对于 Stack Overflow 来说是
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 6 年前。
我刚刚将一个网站部署到 Firebase 托管,它运行良好 - 设置非常简单。 但是,我的问题是,有什么方法可以通过身份验证限制对网站的访问?这是一个只有我的团队才能访问的管理面板。有什么方法可以用密
如果我想托管一个对公众用处不大的应用程序(例如,一个将点打印到控制台的程序,它们的数量取决于现在的时间),我喜欢在启动板中的方式不必乱扔全局托管站点的命名空间并用诸如 HourDot 之类的名称填充它
我是一名优秀的程序员,十分优秀!