写点什么

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

  • 2008-05-19
  • 本文字数:1629 字

    阅读完需:约 5 分钟

Spring 和 JBoss Seam 框架为企业 web 应用的开发分别提供了不同的特性。Spring 是一个 JavaEE 中间件框架,它建立在像 POJO 抽象、依赖注入( Dependency Injection )和面向方面编程( Aspect Oriented Programming )等特性上,它提供了与 Hibernate TopLink iBatis 等框架的集成。而 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 网站的 Spring Seam 专栏获得关于这两个框架的新闻。

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

2008-05-19 14:381461
用户头像

发布了 71 篇内容, 共 23.9 次阅读, 收获喜欢 3 次。

关注

评论

发布
暂无评论
发现更多内容

HarmonyOS SDK,赋能开发者实现更具象、个性化开发诉求

HarmonyOS开发者

HarmonyOS

一个基于Vue3搭建的低代码数据可视化开发平台

互联网工科生

低代码 可视化 Vue3

我院五名学子获第四届“火焰杯”软件测试开发选拔赛全国奖项

霍格沃兹测试开发学社

低代码平台:业务开发的银弹

树上有只程序猿

低代码 应用开发

直播预约丨《实时湖仓实践五讲》第三讲:实时湖仓在袋鼠云的落地实践之路

袋鼠云数栈

大数据 前端 湖仓一体 实时湖仓

数据下钻分析?图表链接一招搞定!

观测云

数据分析 图表链接

Databend 开源周报第 116 期

Databend

1024 | 9位开发者分享生涯“最”时刻,文武状元大PK等你来

华为云开发者联盟

程序员 华为云 1024程序员节 华为云开发者联盟

第四届“火焰杯”软件测试高校就业选拔赛颁奖典礼

霍格沃兹测试开发学社

颠覆者:Telegram 凭借源自中国的云基础设施成为超级应用

FN0

小程序 超级app miniapps

Telegram 应用中正式引入国产小程序技术

Onegun

小程序 超级app 小程序容器技术

重磅官宣 | 第二届OpenHarmony技术峰会,邀您共启智联未来

OpenHarmony开发者

OpenHarmony

河南工业大学人工智能与大数据学院学子在第三届“火焰杯”软件测试开发选拔赛中 取得佳绩

测试人

软件测试

APP采用原生开发还是混合开发,哪种方式好?

Speedoooo

小程序生态 混合开发 小程序技术 小程序容器技术 混合框架

TE智库|《在产业升级大潮中寻求自我突破的中国工业软件产业》报告发布,跟随中国工软追寻卓越的印记

TE智库

智能制造 先进制造 工业软件

音视频常用专业名词解析

X2Rtc

音视频 科普 RTC 基础知识

41个外贸英语表达技巧!

九凌网络

更名 X:Twitter向超级应用的进化之路

FN0

小程序 超级app解决方案

第9期 | GPTSecurity周报

云起无垠

重读Effective JAVA(一)- 精进自己的JAVA技术

xfgg

Java

一图秒懂!从传统大数据平台到云原生大数据平台,再到云原生K8s大数据平台

智领云科技

Kubernetes #云原生 云原生大数据平台

悦数图数据库 x 阿里云计算巢:打造云上超大规模图数据库

悦数图数据库

图数据库

支付宝沙箱超详细教程+避雷经验,看这篇就够了

盐焗代码虾

测试 支付宝 沙箱

当1024程序员节遇上双十一 联想用专业品质PC产品向程序员致敬

科技之家

WorkPlus专注私有化部署,为企业安全打造超级沟通协作APP

BeeWorks

HarmonyOS音频开发指导:使用OpenSL ES开发音频播放功能

HarmonyOS开发者

HarmonyOS

谷歌优化的十种方法

九凌网络

为Web应用构建Spring—Seam混合型组件_Java_Srini Penchikala_InfoQ精选文章