亲爱的 Spring 社区:
我们很高兴地宣布下一代 Spring Web Flow 的首个里程碑版本现已可用。 Spring Web Flow 2.0 M1 引入了几个主要新功能,包括流管理的持久化上下文支持、改进的 Java Server Faces 支持、全面的统一表达式语言 (EL) 支持,以及一个更全面的示例 Web 应用。
Spring Web Flow 2.0 是用于开发 Java Web 应用控制器的下一代框架。 该框架提供了一个统一的运行时环境,可在各种环境中执行无状态和有状态的客户端交互。
Web Flow 2.0 版本的目标
如今,大多数应用开发者通过将 Web Flow 集成到他们的“基础”Web 框架(例如 Spring MVC)中,来使用 Spring Web Flow 实现线性页面流程,例如向导。 此类页面流程具有线性导航规则、有状态,并形成动态的、自包含的 Web 应用功能模块。 一个很好的例子是贷款申请流程:Web Flow 独特的流程定义语言为实现这类流程提供了一种自然的编程模型。
Spring Web Flow 2.0 的总体目标是正式将产品从目前的形态(主要用于实现线性向导的框架)发展到其最初设计的形态:一个为所有类型的客户端交互提供支持的通用应用控制器引擎。 这类交互包括向导、无状态的“RESTful”交互,以及 Web 2.0 应用中常见的更细粒度的、非线性的/异步交互。
Spring Web Flow 2.0 将为 Spring 社区提供一个统一的应用控制器框架和运行时环境,适合执行所有类型的客户端交互,并能够集成各种视图渲染技术和 UI 组件模型。 这个统一的运行时环境将实现管理工具、安全性、AJAX 和托管持久化等独特功能的统一应用。
查看完整的Spring Web Flow 2.0 路线图。
Web Flow 2.0 M1 新特性与要点
首个 2.0 里程碑版本在通往 2.0 最终版本的道路上引入了几个主要的新功能。 这些功能描述如下。
使用 JPA 和 Hibernate 的流管理持久化上下文
Spring Web Flow 2.0 M1 引入了对使用 Hibernate 和 JPA 的流管理持久化上下文的支持。 版本中包含的新酒店预订示例应用展示了这一功能。 以下是在预订示例中的工作方式:
- 当一个新的酒店预订流程开始时,会自动为您创建一个持久化上下文。
- 随着您在流程中前进,持久化上下文将自动用于所有数据访问操作。 您无需担心定位流绑定的 EntityManager 实例,或以任何方式管理它。
- 当您授权预订时,对托管持久化实体的所有更改将自动提交并刷新回数据库。 如果您选择取消预订,则您的任何更改都不会被提交。
以下是此酒店预订流程的Spring IDE 图形视图:
改进的 Java Server Faces (JSF) 支持
Spring Web Flow 2.0 M1 引入了 Spring Faces 模块 (spring-faces-2.0-m1.jar),这是一个随 Web Flow 分发包提供的组件,为使用 Java Server Faces 开发 Web 应用的组织提供一流的支持。 现有的 Web Flow + JSF 集成已被重构到此项目中,并且此项目将成为所有未来 JSF 集成工作的归宿。
Spring Faces 模块为 Spring 社区提供了一个专门的项目,用于探索额外的 JSF 集成机会。 2.0 M1 的初期工作引入了与 Ext 的集成,Ext 是一个流行的 Javascript GUI 小部件框架。 提供了几个轻量级的 JSF UI 组件,封装了丰富的 Ext 小部件的渲染。 我们采用的方法允许 Ext 小部件装饰标准的 JSF 组件,增加了类似桌面的外观和额外的 UI 行为,例如客户端验证。 2.0 M1 中提供了以下 Ext 组件装饰器:
- 一个日期验证器组件,对日期文本字段执行丰富的客户端验证,并带有美观的日期选择器控件。
- 一个文本验证器,对自由格式文本输入字段执行丰富的客户端验证。
- 一个数字验证器,对数字文本字段执行丰富的客户端验证。
日期验证器控件的屏幕截图(也用于酒店预订示例应用)如下所示:
Ext 控件看起来很棒,并且由于所有 UI 行为都在客户端执行,因此 UI 的响应速度极佳。 我们将在未来的 Web Flow 里程碑版本中继续在此领域添加支持,作为 Spring Faces 模块的一部分。
拥有一个专门的 Spring Faces 模块也简化了在 JSF 环境中设置 Spring Web Flow 的过程。 在 2.0 M1 之前,开发人员需要手动修改 faces-config.xml 来设置样板式的 Spring/SWF 集成管道。 有了 2.0 m1,只需在您的 classpath 中包含 spring-faces-2.0-m1.jar,即可自动完成此设置。
统一表达式语言 (EL) 支持
此版本中的另一个新功能是完全支持统一 EL,它提供了 Spring Web Flow 当前默认使用的基于 OGNL 的表达式解析器的替代方案。 现在建议在 JSF 环境中使用统一 EL,并且它将成为未来里程碑版本中 JSF 开发人员的默认选项。
酒店预订流程定义中使用的 EL 表达式示例如下所示:
上面的“id”表达式评估存储在 Flow Scope 中的当前酒店标识符。 请注意,此处无需任何显式的 flowScope 前缀。 开发人员只需按名称引用变量,ELExpressionEvaluator 会通过搜索各种范围来解析变量。 这使得 Web Flow 定义中的托管 Bean 引用与 JSF 视图中用于模型绑定的表达式引用 100% 一致。 例如,请参阅 bookingForm.xhtml 视图中的以下片段:

2.0 发布说明
Spring Web Flow 2.0 需要 Spring 2.0 或更高版本以及 Java 1.4 或更高版本。
Spring Web Flow 2.0 将尽可能保持与 1.0.x 基于 XML 的流程定义语言的向后兼容性。 预计在未来的 Web Flow 2.x 里程碑版本中,随着 Web Flow 演变为一个完整的控制器框架,一些 SWF SPI 将发生变化。
Spring Web Flow 2.0 未来的里程碑版本将引入新的方言,用于在真实的编程语言中定义流程,为当前基于 XML 的流程定义语法提供更强大的替代方案。 正在开发基于 POJO 的 Java 流程定义语法以及基于 Groovy 的方法。 此外,还将引入用于实现 REST-ful 和 CRUD 流程的高级流程方言。 由于 Web Flow 定义 API 和执行运行时与任何具体的流程定义语法是分离的,我们可以自然地引入新的语法,以不同的方式在运行时构建应用控制器。
对于 JSF 用户,Spring Web Flow 2.0 和 Spring Faces 可在 JSF 1.1 和 JSF 1.2 上运行。 Spring Faces 模块中的 UI 组件库独立于 Web Flow 运行时,也可与 JSF 的默认导航处理器一起使用。
Spring Web Flow 2.0 将继续全面支持 Servlet 2.4 或更高版本、Portlet 1.0 或更高版本以及 JUnit 3.8.1 或更高版本的环境。
Spring Web Flow 2.0 将继续在 Struts 1.2 或更高版本以及 Spring MVC 2.0 或更高版本的环境中运行,并且到 2.0 最终版本时,它也将可用作独立的 Web 应用控制器框架。