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

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

    SEAM选用的是重量级J2ee组件

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

    spring则正好相反

深度内容

和Google互补的搜索引擎Wolfram|Alpha

Wolfram|Alpha与Google究竟是什么关系,Wolfram|Alpha自己是如何定位的?Wolfram|Alaph在多大程度上是语义网搜索呢?InfoQ中文站就等等这些问题采访了Wolfram研究公司中国区商务经理王翔。

SOA契约成熟度模型

本文说明了所推荐的契约版本管理设计策略是如何与SOA成熟度模型发生联系的。文章目的是为实现版本管理和可组合性提供一个路线图。

数据服务简介

Vijay Narayanan在这篇文章中对数据服务的几个方面进行了介绍,它们都是SOA实践者和数据架构师感兴趣的内容。本文对数据服务的几个方面进行了介绍,包括需求定义,基本原理和好处、范围、开发以及消费模式。

分块云计算

在本文中,Jimmy Nilsson描述了一种他在过去数年间观察到的一种正在缓慢成长的架构风格,他把这种风格称为“分块云计算”。

豆瓣网技术架构变迁

罗马不是一天建成的,豆瓣的技术架构也是随着用户规模的增长一直在持续变化中。在本次演讲中,豆瓣的首席架构师洪强宁将与大家一起分享从上线时的单台服务器架构开始一直到现在的豆瓣架构变迁历程。

融合思想:深入探索S#arp架构

Billy McCafferty展示了S#arp架构,它在ASP.NET MVC框架的基础上,荟萃了当今的最佳实践,应用在ASP.NET Web应用程序的架构设计中。

王雷谈开源以及新兴市场计划

中国作为新兴市场中的新兴市场,是Sun在美国之外实施SSE(SUN Startup Essentials)项目重点关注的地区。在QCon Beijing 2009期间,InfoQ中文站有幸对此项目的负责人王雷先生进行了采访,探讨了关于开源、新兴市场、SSE等话题。

使用HTML5构建下一代的Web Form

HTML5 是由 WHATWG发起的,最开始的名称叫做Web Application 1.0,而后这个标准吸纳了Web Forms 2.0的标准,并一同被W3C组织所采用,合并成为下一代的HTML5标准。