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

阅读数:297 2008 年 5 月 19 日

话题:JavaWeb框架语言 & 开发

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