gpt4 book ai didi

cdi - 将 bean 解析委托(delegate)给另一个 IoC 容器

转载 作者:行者123 更新时间:2023-12-05 05:33:07 25 4
gpt4 key购买 nike

回到中年,我的公司创建了他自己的 IoC 容器,从那时起我们的应用程序就在它上面运行。但我们改用 CDI/Weld 的日子已经到来。我们不想将整个事情切换到 CDI(老实说不能......),而是希望从我们的前端 JSF 开始一点一点地做这件事。

我们的想法是将一些 bean 解析留给 Weld(例如 Controller ),一些留给我们旧的 IoC 容器(例如服务)

例如:

@Named
@RequestSCoped
ControllerA {

@Inject
private ServiceB service:
}

ControllerA 应该由 Weld 管理,ServiceB 应该保留在我们旧的 IoC 容器中。不过,Weld 应该知道如何解决它。

到目前为止,我们最好的线索很可能是使用 cdi 扩展并处理生命周期事件。欢迎提供任何示例、反馈或建议。

最佳答案

首先,欢迎来到CDI!这是一个很棒的框架,使用起来很愉快,尤其是与 JSF 结合使用时。我推荐阅读 JavaEE8 中的 Pro CDI:https://link.springer.com/book/10.1007/978-1-4842-4363-3深入研究这将有助于解释我在下面的答案

您应该选择几条路线。最简单的方法是在委托(delegate)给旧 IOC 容器的类中使用 @Produces 注释。示例见此处:https://www.baeldung.com/java-ee-cdi

真正巧妙但稍微复杂的方法是创建一个 CDI 可移植扩展,它可以将解析委托(delegate)给您的旧容器。这非常强大,可以让您连接到 CDI 容器的多个部分。有关引用,请参见此处:https://docs.jboss.org/weld/reference/latest/en-US/html/extend.html#extend

在任何一种情况下,您都必须彻底了解 CDI 生命周期(一切都是委托(delegate)给托管实例的代理)以及它如何与现有 IOC 容器交互,否则您可能会面临内存泄漏。

祝你好运!

关于cdi - 将 bean 解析委托(delegate)给另一个 IoC 容器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/73907706/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com