InfoQ

新闻

为Web应用构建Spring—Seam混合型组件

作者 Srini Penchikala译者 沙晓兰 发布于 2008年5月19日 下午2时38分

社区
Java
主题
Web框架
标签
JBoss Seam,
Spring框架

Spring和JBoss Seam框架为企业web应用的开发分别提供了不同的特性。Spring是一个JavaEE中间件框架,它建立在像POJO抽象、依赖注入(Dependency Injection)和面向方面编程(Aspect Oriented Programming)等特性上,它提供了与HibernateTopLinkiBatis等框架的集成。而Seam则是一个集成了如AJAX、Java Server Faces (JSF)、企业Java Beans (EJB3)、Java Portlets及业务流程管理 (BPM)等技术的web应用框架。在开发web应用的过程中,这两者能否结合起来使用或者同时应用这两个框架是否有意义呢?最近有篇文章就专门讨论了这个话题,而且,在java社区论坛上也主要关于如何将这两个框架结合使用并各取所长展开了激烈的讨论。

Dan Allen最近写了两篇关于如何将Spring和Seam框架集成到web应用中的文章。在第一篇文章中,他解释了如何利用Seam和Spring容器功能来创建混合型组件。他说,Seam统一了JSF、JPA、EJB 3和其他一些技术,但它不支持Spring所能提供的一些简易特性,比如轻量级远程技术(lightweight remoting)、AOP声明、框架模板类(framework template classes)以及资源注入(resource injections)。而这些Seam不支持的功能点,就是能够或者说值得创建Spring-Seam混合组件的地方,我们可以在这些地方创建可以同时从Seam和Spring容器的功能中获益的对象。Seam提供模块支持将Spring框架集成到web应用中,也支持关于应用组件和底层资源的共享。

作者通过一个web应用实例,向读者阐述了如何通过使用Seam提供的ContextLoader组件和将seam:component内嵌到Spring元素中把Spring“装饰”成一个Seam组件的方式,最终将Spring beans集成到Seam应用中。他也提到了另一个将Spring和Seam集成的方法,那就是使Seam容器与Spring之间通过使用定制的EL(表达式语言)解析器来通信。

在该系列文章的第二部分中,他谈到了将状态行为添加到Spring bean中的话题,这个性能目前如果单单使用Spring框架来实现的话还是一个极大的挑战。Spring beans中可以添加状态(State)信息,只需要注册一个Seam定制范围处理器使Spring beans能够被存储在Seam上下文中,从而可以为实现POST提交后重定向(redirect-after-post)机制而维持暂时通信、为单用户页面流程(single-user page flows)提供长运行时会话(long-running conversation)、以及支持多用户在扩展时间段内交互的业务流程范围。这样一来,Spring beans就没有必要对HTTP session重新排序就能获知各自的状态。

作者还讨论了在同时使用Spring和Seam的时候会遇到的域和线程安全问题。Spring仅在创建时注射一次依赖性,但Seam则可以在每个方法被调用之前进行动态注射。如果一个bean由于被附加到一个生命周期较长的组件上而导致其自身生命周期比预期生命周期更长的话,那么两者间的设计哲学的差别会导致域阻抗(scope impedance)问题。通过Spring的静态依赖注射将组件捆绑到不同域的时候,就会导致前面这种情况的出现。Seam提供的解决方案有助于避免域阻抗和线程安全问题,也就是,不要直接应用“ref”元素来注射bean实例,而使用seam:instance标签来注射代理。

社区论坛关于这个话题也有很多有趣的讨论。Rick Hightower综述了Seam 2.0.1的特性,并引发了关于同时使用Seam和Spring的讨论。在讨论中提到的一些问题有:

  • 假设你一直同时在使用Seam和Spring,如果有一天你必须只能从中选取一个,你会选哪个?
  • 你使用Seam的同时是否也用到EJB 3?
  • 你使用Seam的同时是否也用到Spring?
  • Seam的生成工具好用吗?
  • Seam是不是编写基于JPA和JSF的应用的最好的方式?
  • 你觉的Spring和Seam在哪些方面互相有所重复,在重复的功能方面,你觉的哪个更好用?

Spring 2.5.4版本和Seam 2.0.1 GA版本都是最近才发布。你可以从InfoQ网站的SpringSeam专栏获得关于这两个框架的新闻。

查看英文原文:Building Spring-Seam Hybrid Components For Web Applications

1 条回复

回复

SEAM选用的是重量级J2ee组件 发表人 index chen 发表于 2008年5月20日 下午10时11分
  1. 返回顶部

    SEAM选用的是重量级J2ee组件

    2008年5月20日 下午10时11分 发表人 index chen

    spring则正好相反

独家内容

David Nuescheler谈JCR和REST

在这篇访谈中,Day公司CTO和JCR规范组长David Nuescheler讨论了JCR(Java内容仓库标准)的优点、JCR与诸如Atom/Atom发布协议这种API之间的区别、JCR与REST的联系,以及一个新的Web框架——Apache Sling。

使用BlazeDS和AMF构建Web和桌面应用

客户/服务器通信是当今RIA构架的核心。James Ward和Shashank Tiwari在本文中就深入探讨了Adobe的开源BlazeDS消息服务器。

程立谈架构、敏捷和SOA实践

支付宝首席架构师程立在本文分享了支付宝技术架构的发展,对架构的认识,成功架构的特点,如何避免架构设计的失败,以及在敏捷和SOA方面的实践等。

Emmanuel Bernard谈Bean验证规范

InfoQ有幸采访到了Emmanuel Bernard,向其了解Bean验证框架及专家组正在寻求的社区参与的更多相关信息。

通过索引器简化C#类型信息访问

作为一个有别于Java、Ruby等语言的一个特性,C#可以用索引器(Indexer)将类型本身以对象数组的形式供外部使用。同时,把索引器和LINQ结合使用倒是一个非常不错的组合,索引器做接口、LINQ完成内部检索逻辑,客户程序在无需记住具体方法名称的前提下,按照键值检索即可,索引器内部则依托LINQ to系列的基础,提供对各种异构数据源的访问。

产品负责人成功之道

Scrum中,产品负责人这个角色具有很大的影响力,能够带来很高的价值。但要想运用得当,可没那么轻而易举。如果做得好,就可以在客户和开发者之间建立更为融洽的关系,并能够增加组织的竞争优势。

硝烟中的Scrum和XP

在本书中,作者Henrik Kniberg讲述了他在一年的时间里,带领40人的团队实施Scrum的过程。他们试过了多种团队尺寸(3~12人)、sprint长度(2~6星期),定义“完成”的不同方式,不同的backlog格式,各种测试策略,在多个Scrum团队之间进行同步的多种方式。他们还尝试过XP实践——持续集成、结对编程、测试驱动开发等等,还试过了把XP跟Scrum组合。

软件开发中的准时化生产

准时化生产(Just In Time)是精益生产(Lean Production)和丰田生产系统(Toyota Production System)中的概念,敏捷开发与准时化生产中的很多观点和实践是一致的,精益思想作为精益生产背后的指导思想也正在积极地影响着软件开发领域,向其中不断注入创新与活力。