在JavaEE应用的开发中,常常有人选择了JSF作为视图层框架,但是却基于传统思维抛弃了JavaEE的CDI,而选用了Spring DI。
这不仅造成了框架的错配,而且集成JSF与Spring容易造成开发人员的混乱。下面重点介绍集成JSF与Spring的现状和存在的问题。
JSF与Spring的集成,主要体现在JSF的组件访问Spring的组件上,具体就是JSF的ManagedBean注入Spring Bean的服务上。
1. JSF的ManagedBean,就是个普通的Java Bean,由JSF框架创建并管理
UI组件的数据模型用于JSF页面中访问数据
1) 定义ManagedBean
JSF 1.2中必须在faces-config.xml中配置
JSF 2.0开始使用@ManagedBean(name = "...", eager = true),默认eager=false即延迟实例化
@RequestScoped,默认
@SessionScoped
@ApplicationScoped
@NoneScoped,页面中的EL表达式,渲染时创建,然后立刻销毁
@ViewScoped,UI发出HTTP请求一个JSF视图时创建,UI发出HTTP请求其他JSF视图时销毁
@CustomScoped
3) JSF的ManagedBean的依赖注入:
@ManagedProperty2. Spring的Bean,就是个普通的Java Bean,由Spring框架创建并管理
UI组件的数据模型
用于视图层访问数据
1) Spring的Bean的有效范围:
@Scope("request")@Scope("session")
@Scope("singleton") ,默认
@Scope("prototype")
2) Spring的Bean的依赖注入:
@AutoWired3. Spring提供的SpringBeanFacesELResolver,可以在JSF的EL表达式中访问Spring的服务。
必须在faces-config.xml中配置
<faces-config ...>
<application>
<el-resolver>org.springframework.web.jsf.el.SpringBeanFacesELResolver</el-resolver>
</application>
</faces-config>4. 存在的问题:
为了能够支持视图层的访问,JSF的ManagedBean必须实现Serializable接口,但是其所依赖的Spring Bean未必实现Serializable接口;
JSF的ManagedBean和Spring的Bean,都可能依赖各自不同的其他Bean,但是注入依赖Bean的方式各不相同,不能混淆;
JSF的ManagedBean的有效范围与Spring的Bean的有效范围不完全匹配。
参考文献:
http://www.beyondjava.net/blog/integrate-jsf-2-spring-3-nicely/
本文关注于JSF的ManagedBean与Spring Bean的比较及集成问题。在JavaEE开发中,选择JSF但使用Spring DI可能导致框架错配。集成难点在于JSF ManagedBean如何注入Spring Bean。文中讨论了ManagedBean的定义、生命周期,以及两者依赖注入的差异,并指出JSF与Spring Bean的有效范围不匹配的问题。

1034

被折叠的 条评论
为什么被折叠?



