Spring Web Flow 2.0 入门
本教程分析了 Spring Web Flow 2.0 的技术要点,并且通过创建一个示例应用程序,展示了 Spring Web Flow 2.0 的基本知识。
开始之前
关于本教程
本教程通过一个简化的购物车应用,介绍了如何使用 Spring Web Flow 2.0 来构建 Web 应用程序。本教程以讲解实例为主,为了读者更好地理解 Spring Web Flow ,也有部分理论的解释。
先决条件
本教程要求读者具备 Java Web 应用的基本知识、熟悉 Spring Framework 的应用。
系统要求
运行本教程中的示例,需要下列工具:
∙JDK 1.6.0+
∙Spring Framework 2.5.4+ 及其依赖项
∙Spring Web Flow 2.0.2
∙Tomcat 6.0.0+ (为支持 EL , Tomcat 须 6.0 及以上版本)
∙eclipse 3.2.2+
Spring Web Flow 2.0 新特性
Spring Web Flow 是 Spring 的一个子项目,其最主要的目的是解决跨越多个请求的、用户与服务器之间的、有状态交互问题。最新版本为 2.0 ,相比于 1.x 版的 Spring Web Flow ,有以下几个值得注意的新特性。
∙与 Spring MVC 深度整合
Spring Web Flow 1.x 是个自成体系的框架,可与 Spring Web MVC 、
Struts 、 JSF 等 Web 框架整合。最新的 Spring Web Flow 2.0 则明确声明是基于 Spring Web MVC 的一个扩展。
∙提供了处理 Ajax 事件的能力
Ajax 事件的处理与 Web Flow 事件的处理相一致,在处理完成后, flow 即可刷新客户端相关界面代码。
∙与 JSF 整合
通过将 JSF 层层包装,最终可在 Spring Framework 和 Spring Web Flow 中使用 JSF 的各种组件。
∙与 Spring Security (原 Acegi Security )整合
只需将某个 flow 声明为“ secured ”,即可利用 Spring Security 来确定当前用户是否有权限运行 flow 、激发事件等等。
∙更简洁的配置
官方的数据说同一个 flow , 2.0 版的配置比 1.x 版的配置少 50% 的 XML 代码。
∙重用更方便
Spring Web Flow 2.0 提供了 flow 的继承,重用即有的 flow 代码更加容易。
本教程的说明
本教程主要讨论 Web Flow 模块的使用,对其他的特性没有涉及。
购物车用例
要了解 Spring Web Flow 是什么东西,最好的办法莫过于查看示例,图 1 展示了一个简化的购物车的流程。
图 1 购物车示例
图 1 所示流程用 Spring Web Flow 2.0 的配置文件表示如下:
清单 1 用 Spring Web Flow 语义表达购物车流程菜鸟教程springmvc
……
<flow>
<view-state id="viewCart">
<transition on="submit" to="viewOrder"/>
</view-state>
<view-state id="viewOrder">
<transition on="confirm" to="viewConfirmed"/>
</view-state>
<view-state id="viewConfirmed">
<transition on="returnToIndex" to="returnToIndex"/>
</view-state>
<end-state id="returnToIndex"/>
</flow>
清单 1 省略了许多技术细节,展示的只是一个业务的流程,主要是为了让大家对 Spring Web Flow 的语义有个初始的印象。从清单 1 中,应注意到一个很重要的特征—— Spring Web Flow 语义与 Servlet API 无关。更确切地讲,Spring Web Flow 语义关注的是业务的流程,并未与 Sun 公司的 Web 规范紧密结合,这种描述是更高层次的抽象,差不多是在建模的角度来描述业务流程。
不过, Spring Web Flow 也并非只有抽象,现在还没有哪一种工具或语言可以将一个模型直接转换成相应的应用程序。 Spring Web Flow 更像是抽象建模和技术细节的混血儿,相比于湮没在繁多的控制器和视图中的 Web MVC 应用来讲, Spring Web Flow 提供了如清单 1 所描述的更高层次的抽象,但同时它也整合了像 Unified EL 这样的工具来控制技术上的细节。
Spring Web Flow 的基本元素
Flow 可看作是客户端与服务器的一次对话( conversation )。 Flow 的完成要由分多个步骤来实现,在 Spring Web Flow 的语义中,步骤指的就是 state 。 Spring Web Flow 提供了五种 state ,分别是 Action State 、 View State 、 Subflow State 、 Decision State 、 End State ,这些 state 可用于定义 flow 执行过程中的各个步骤。除了 End State 外,其他 state 都可以转换到别的 state ,一般通过在 state 中定义 transition 来实现到其他 state 的转换,转换的发生一般由事件( event )来触发。
什么情况下可以使用 Spring Web Flow?
前面讲了, Spring Web Flow 提供了描述业务流程的抽象能力,但对一种 Web 开发技术而言,仅有这些是不够的。同时, Spring Web Flow 是不是能够取代其他 Web MVC 技术?或者在任何情况下都应优先使用 Spring Web Flow ?要回答这些问题,先来看一下 Spring Web Flow 所着力解决的技术问题。
Web 应用程序的三种范围
Java Servlet 规范为 Web 应用程序中用到的各种对象规定了三种范围( scope ),分别是 request 范围、 session 范围和 application 范围。
∙request 范围中的对象是跟客户的请求绑定在一起的,每次请求结束都会销毁对象,而新的请求过来时又会重新创建对象。 request 范围适合存
放数据量较大的临时数据。
∙session 范围中的对象是跟会话( session )绑定在一起的,每次会话结束会销毁这些对象,而新的会话中又会重新创建。 HTTP 协议本身是无状态的,服务器和客户端要实现会话的管理,只能借助于一些辅助的手段,如在协议的数据包中加一些隐藏的记号,等等。 session 范围适合存放
本次会话需要保留的数据。
∙application 范围的对象是跟应用程序本身绑定在一起,从 Servlet API 的角度来讲,就是存放在 ServletContext 中的对象,它们随着 Servlet 的启动而创建, Servlet 关闭时才会销毁。 application 范围适合存放那些与应用程序全局相关的数据。
现实开发中最令人头痛的莫过于 session 范围, Java Servlet 规范指明可在 l 中按如下方式配置 session 的有效时间为100分钟:
清单 l 中 session 的配置
<session-config>
<session-timeout>100</session-timeout>
</session-config>
然而,现实中的 session 范围更像是“鸡肋”,把大量数据放入 session 会导致严重的效率问题,在分布式的环境中处理 session 范围更是一不小心就会出错,但抛弃 session 又会给开发带来许多不便。 request 范围虽说能存放量大的数据,但有效范围有限。摆在开发者面前的很多用例都要求一种比 request 范围要长,但又比 session 范围要短的这么一种有效范围。
Spring Web Flow 的解决方案
针对 Java Servlet 规范中的这个缺陷, Spring Web Flow 2.0 中提供了以下两种范围:
∙flow 范围。此范围内的对象在 flow 开始时创建, flow 结束时销毁,在 flow 定义文件中可通过“ flowScope ”变量名来访问。
∙conversation 范围。此范围内的对象与 flow 范围对象基本相似,唯一不同在于 conversation 范围内的对象所在的 flow 如果调用了其他
subflow ,那么在 subflow 中也可访问该对象。
由于 flow 是由开发人员自己定义的,可根据业务的需求自由改变, flow 范围和 conversation 范围的使用也就突破了 Java Servlet 规范中 session 范围和 request 范围的局限,真正做到了自由定制。
并非所有情形都适用 Spring Web Flow
可以看出, Spring Web Flow 所着力解决的问题即是客户端与服务器的对话( conversation )问题,这个范围比 request 要长,而比 session 要短。为实现 conversation 范围(即 flow 范围),需要付出效率上的代价,因此,并非所有 Web 应用都适合使用 Spring Web Flow 。 Seth Ladd 等人所著 Expert Spring MVC and Web Flow 一书,对何时使用Spring Web Flow,列出了如下表格。
表 1 何时使用 Spring Web Flow
解决方案 何时使用
Spring MVC Controller 某个单独的、只需较少业务逻辑就可创建
的页面,同时该页面不是 flow 的一部分Spring MVC SimpleFormController 某个只涉及表单提交的页面,如一个搜索
框
由一系列导航页面组成的业务过程 Spring MVC
AbstractWizardFormController
Spring Web Flow 任何比较复杂的、有状态的、需要在多个
页面之间跳转的业务过程
Spring Web Flow 的其他特点
Web Flow 作为一个单独的概念被提出来,也可算是 Spring Web Flow 的一大亮点。目前大多数 Web MVC 框架都把重点放在各种 controller 和形形的 view 技术上面,对 Web 应用流程本身的关注是不够的, Web Flow 的提出就提供了一层抽象,设计者就可以从 Web Flow 抽象层面来进行设计、开发。当然, Web Flow 不能理解为只是 Web 页面间的跳转流程,定义 Spring Web Flow 的语义并非只限于页面之间的跳转,而可以是 Web 应用中的各种行为。由此,用例的模型建构好以后,就可直接从该模型转换到相应的 Web Flow,开发人员的设计变得更加直观、有效。
另外,在 Spring Web Flow 中重用 Web Flow 是比较容易的。在定义 flow 、state 时可通过继承某个已有的 flow 或 state ,来避免重复定义。同时,一个 flow 可以调用其它 flow ,就跟一般程序语言中在某个函数内部调用其它函数一样方便。
配置 Spring Web MVC
Spring Web Flow 2.0 就是 Spring Web MVC 的一个扩展,如果粗略一些来讲,所谓 flow 就相当于 Spri
ng Web MVC 中一种特殊的 controller ,这种 controller 可通过 XML 文件加以配置,因此在使用 Spring Web Flow 2.0 前须先对 Spring Web MVC进行配置,步骤如下:
∙创建 Web 应用的目录结构
∙在 /WEB-INF/lib 下导入相关类库
∙在 Web 应用部署描述符文件 l 中声明 DispatcherServlet 并指定配置文件
∙添加 DispatcherServlet 映射
∙创建 l 文件
∙创建 l 文件
∙创建 index.jsp
创建 Web 应用的目录结构
本示例应用将采用 eclipse Dynamic Web Project 向导默认生成的目录结构,在 WEB-INF 目录下添加 config 和 flows 子目录,其中 config 子目录用来存放各种配置文件, flows 子目录下存放 Spring Web Fl
ow 的定义文件。最后目录如图2所示:
图 2 目录结构
在 /WEB-INF/lib 下导入相关类库
只需将以下几个 jar 包导入 /WEB-INF/lib 目录下就可以了: ∙commons-logging.jar
∙jstl.jar
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论