写点什么

为 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:381315
用户头像

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

关注

评论

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

Last Week in Milvus

Zilliz

非结构化数据 开源社区 Milvus Zilliz

拜托,别在agent中依赖fastjson了

夏奇

Java Agent 类加载 架构设计 Fastjson

Python超实用!批量重命名文件/文件夹,只需1行代码

程序员晚枫

Python 文件管理 自动化办公

文心大模型企业应用私享会·上海站:共话大模型前沿技术与产业应用创新

飞桨PaddlePaddle

人工智能 百度 paddle 飞桨 百度飞桨

openGauss-graph 0.1.0版本正式发布

daydayup

PoseiSwap:首个基于模块化设施构建的订单簿 DEX

西柚子

openGauss企业级开源数据库荣获2022年度中国计算机学会(CCF)科技进步奖特等奖

daydayup

2023模式识别课程师资培训会重磅招募

飞桨PaddlePaddle

人工智能 百度 paddle 飞桨 百度飞桨

Ansible自动化部署安装openGauss 3.1.0 企业版

daydayup

敏捷产品路线图管理实例,产品路线图工具

顿顿顿

Scrum 敏捷开发管理 产品路线图工具

PoseiSwap:首个基于模块化设施构建的订单簿 DEX

BlockChain先知

2023年7月文章一览

codists

编程人生

【我与openGauss的故事系列】奇思妙想——通过Go语言自制安装openGauss二进制程序(一)

daydayup

大模型真的会“好事多模”吗?

脑极体

大模型

文心一言 VS 讯飞星火 VS chatgpt (69)-- 算法导论6.5 8题

福大大架构师每日一题

福大大架构师每日一题

千云探探监测到7月25日法国巴黎Facebook网络恢复正常

郑州埃文科技

网络性能

PoseiSwap:首个基于模块化设施构建的订单簿 DEX

股市老人

微信朋友圈的高性能复杂度架构

艾瑾行

#架构训练营

深入浅出DAX:数据分析

TiAmo

数据分析 数据处理 DAX

京东云正式加入openGauss社区,共筑数据库科技服务供应链

daydayup

开放原子开源基金会TOC(技术监督委员会)第七十七次全体会议

开放原子开源基金会

【我与openGauss的故事系列】奇思妙想——通过Go语言自制安装openGauss二进制程序(二)

daydayup

DBMind索引推荐功能在民生银行的生产实践

daydayup

openGauss 3.1.0 版本gs_stack功能解密

daydayup

openGauss的高效数据压缩算法

daydayup

覆巢之下(1)

于哲

Sprint Boot学习路线3

小万哥

Java spring 后端 springboot SpringCloud

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