理解seam的conversation
几乎所有对seam进行介绍的文档中都会用大量的篇幅来说明会话(conversation),因为它是seam的发明,让seam与众不同的一个地方。但是要完全理解和运用conversation并不是容易呀。会话是一种用来存储程序上下文数据的容器,和session类似,只不过它的生存周期和session有很大的差别。 会话分成两类,临时会话和长会话。临时会话会开始于服务器端处理客户端的post请求,结束于下一个页面的生成。也就是说,它存在于post->redirect->get 这样一个小周期内。典型的例子是facesmessage组件。这是一个会话内的组件。我们在处理post请求时,写的message,在下个页面生成的时候依然有效。比如,用户提交一个注册表单,表单POST提交后,服务器调用注册方法,在方法结束的时候,调用facesmessage设定信息“注册成功了!”。然后服务器发送一个跳转的response让浏览器转向index页面。在index页面里,我们输出facesmessages里的内容,这时,这个message能够成功的拿到。因为那个facesmessage组件跨越了那一次跳转。之后,如果提交index上的表单的话,又会有一个新的临时会话产生,之前的会话里的内容将不再存在。长会话可以存活得更长。如果在一个短会话内,程序中执行了带有@Begin的方法,或者在page.xml里有配置<begin-conversation>,那么这个临时会话,就会变成一个长会话。如果服务端在执行方法时遇到标有@End的标注,或者在page.xml里遇到<end-conversation>,当前的长会话,将会结束;否则,它会一直持续下去。 会话与JPA的entityManager的关系。一个entityManager与hibernate的session相当。JPA里定义的entityManager一级缓存的刷新方式只有两种:Auto和commit。seam发明了第三种方式,Manual。Auto意味着,当执行到select语句时,entityManger会自动执行一下flush()方法,commit会在事务提交时flush();而Manual则是由你自己来手动控制flush()。每次开始一个会话的时候,seam都会为你开启一个entityManager,这个entityManger会一直打开,直到conversation结束。这是seam的作者Gavin最骄傲的地方了。能让hibernate的session持续在一个会话之内,可以在会话期内的几次服务器与客户端的几次交往中避免LazyInitializationException,最大程度的发挥hibernate延迟载入的能力。其实Gavin最初要把服务端做成这样有状态的,就是因为他认为与orm协作的最佳方式,就是让服务端有状态。 长会话的结束。默认的情况下,当遇到<end-conversation>或@End时,会话并不会立刻结束,而是会在下个页面生成之后才结束,这是为了避免生成页面时无法取到前一个页面POST时处理的结果。但是有的时候,我们确实需要在POST之后,下个页面生成之前就结束掉。这时需要用@End(beforeRedirect=true),或 <end-conversation before-redirect="”true”">。 会话的维持。我们都知道session是靠一个叫JSESSIONID的cookie或者请里的参数来维持的。类似的会话也是通过这么一个特殊的请求参数来控制的,默认为cid。观查cid的变化,能帮助我们查看conversation的变化。 为什么要发明会话呢??这得从seam的作者Gavin说起。这个牛人发明了杰出的ORM框架hibernate,但是却发现现在的web开发方式并没有正确的使用它。和 hibernate搭档最多的当属spring了。在结合spring使用hibernate的时候,我们很难把握得好hibernate session的范围,如果太窄,那么在这个范围之外对持久对象的调用很容易产生LazyInitializationException。所以后来OpenSessionInView的方式很流行。但这还是不能完全解决问题。OpenSessionInView把session的范围扩大到了对一个http request的处理过程之中,而不能处理跨页面的情况。如果把hibernate session扩大到 http session范围内,这显然会让session太长,引发其它问题。所以Gavin觉得需要一种能够跨越页面,并且又不会像http session那样太长的Scope,于是conversation就诞生了。在开发中,尤其是以提交表单方式为主的企业开发中,常常需要用几个页面来配合完成一个用例,这几个页面内的数据往往耦合性强,需要被放到同一个上下文中,而这个上下文用conversation来做也是很自然的。对于Gmail这样的应用,conversation没什么意义。 Conversation是个好东西,但是一定要小心的使用。一来它存在着性能问题 ,二来用的太多,不小心控制conversation的开始和结束,就会导致conversation的混乱,那个时候会导致一些奇怪的问题。
申明:此博客从http://sulong.iteye.com/blog/213338转载过来的
分享到:
相关推荐
1. **Seam架构**:理解Seam如何将组件、事件和依赖注入结合在一起,提供统一的编程模型。 2. **JSF集成**:学习如何利用Seam增强JSF,实现更强大的用户界面交互。 3. **EJB 3.0集成**:探讨Seam如何简化EJB的使用,...
2. **理解Seam业务(Conversation)**:重点讲述了Seam如何管理用户会话,保持业务上下文的一致性。 3. **Seam的UI控制库**:详细介绍了Seam提供的各种UI组件,帮助开发者快速构建美观且功能丰富的用户界面。 4. **...
通过分析这些源代码,我们可以深入理解Seam框架的核心功能和用法。 1. **README.txt**:这个文件通常包含了项目的基本信息,如如何构建、运行和理解源代码,是初学者了解项目的入口。 2. **bpm**:Business ...
- **理解 Seam 业务对话 (Conversation)**:解释了 Seam 如何通过对话管理来处理用户的会话。 - **Seam 的 UI 控制库**:介绍了 Seam 提供的一系列 UI 控件,用于增强用户界面的交互性。 - **Seam 调试页面**:介绍...
在Seam框架提供的示例中,包含了多个具体应用场景下的实践案例,这些例子不仅帮助开发者快速上手Seam,还能深入理解框架的设计思想和技术细节。 ##### 1. 注册示例 (Registration Example) - **理解代码**:此示例...
1.6.3. 理解Seam 业务对话(Conversation)................................................................................................................. 48 1.6.4. Seam 的UI 控制库.........................
- **理解 Seam 业务对话(Conversation)**:解释了业务对话在 Seam 中的作用和意义,以及如何设计有效的对话来提高用户体验。 - **Seam 的 UI 控制库**:介绍了 Seam 提供的一系列 UI 控件,这些控件可以帮助开发者...
此示例主要展示了如何使用 Seam 2.1 构建一个简单的注册表单,并通过代码理解 Seam 2.1 中的核心概念,如 **Seam Components** 和 **Validation**。 - **Understanding the code**:通过代码学习如何定义 Seam 组件...
### Seam 例子 Hello World #### 一、Seam框架简介 Seam是一个强大的企业级Java Web框架,由JBoss组织开发。它通过整合EJB3和JSF等技术,简化了开发过程,使得...希望这个示例能帮助你更好地理解Seam框架的基础用法。
它包括了预订流程的各个方面,比如房间选择、客户信息录入、支付等环节,并深入探讨了Seam对话(conversation)的概念。 - **嵌套对话扩展**(Nested conversations: extending the Hotel Booking example):在此...
- **理解Seam业务对话(Conversation)**: - 业务对话是Seam的核心概念之一,用于管理用户的会话。 - 它可以帮助开发者更好地处理用户交互过程中的状态管理问题。 - **Seam的UI控制库**: - 提供了一系列的UI控件,...
Seam2.0的核心概念包括页面流(Page Flow)、会话范围(Conversation Scope)、事件(Event)以及组件(Component)。其中: - **页面流**:用于组织和管理用户界面的导航流程,它使得页面之间的跳转更加有序和可...
通过理解并熟练运用这些组件,开发者可以更好地驾驭Seam框架,实现复杂的业务逻辑和用户体验。提供的参考资料《Seam 2.0 Reference》中文版(CHM和PDF格式)是深入学习Seam 2.0不可或缺的资源。
6. **对话:Seam 的工作单元 (The Conversation: Seam's Unit of Work)** - **对话概念**:Seam 通过对话的概念来管理应用程序的状态,确保每个对话都是一个独立的工作单元。 - **应用场景**:例如,在电子商务...
描述:本书是关于Seam框架的参考指南,旨在为Java EE 5开发者提供深入理解与应用Seam的知识点。 ### Seam框架概览 Seam框架是为Java EE 5环境设计的一个企业级应用程序框架,它极大地简化了开发过程,提供了更为...
- 编写Seam组件,包括Managed Beans、Entity Beans、Conversation管理等。 4. **部署到Geronimo**: - 构建Seam应用,生成相应的WAR或EAR文件。 - 登录到Geronimo管理控制台(默认地址:...
本篇内容将深入探讨Seam框架的基础概念及其核心特性,并通过几个典型的示例来帮助读者更好地理解和掌握Seam的应用。 #### 一、Seam框架简介 Seam是一款开源的Java EE框架,它基于JavaServer Faces (JSF) 和 EJB ...
3. **核心组件**:深入探讨了JBoss Seam的关键组件,如Conversation Scope、Event System、Component Model等,并解释了它们如何协同工作以实现复杂的业务逻辑。 4. **Web 2.0应用开发**:讲解了如何利用JBoss ...