写点什么

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

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

关注

评论

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

我国区块链产业发展面临的问题

CECBC

Kubernetes手记(17)- 调度策略

雪雷

6月日更

电商微服务架构设计

俞嘉彬

架构实战营

模块六-创业公司电商微服务

华仔架构训练营

大型分布式 Web 系统的架构演进

xcbeyond

分布式 架构演进 6月日更

Redis入门二:数据类型

打工人!

redis 6月日更

聊聊 Redis 过期键删除策略

蘑菇睡不着

Java redis

同被指责「电力浪费」,如今的区块链会是 1999 年的互联网吗?

CECBC

[译] R8 优化:值假设

Antway

6月日更

Flink State 和 Fault Tolerance(三)

Alex🐒

flink 翻译 flink1.13

架构实战营模块6课后作业

大肚皮狒狒

你多久没有换手机了?

看山

闲聊 6月日更

架构训练营模块6作业

Neil43

架构训练营

架构实战营模块6作业

冬天的树

拆分电商系统为微服务

9527

架构实战营

推荐算法工程师需要的知识储备(十三)

Databri_AI

算法 推荐系统 成长路线

☕【JVM技术探索】各种类型对象占用内存情况分析(上)

码界西柚

JVM java对象分析 6月日更 内存分配

因女性而繁荣,适老化科技的钱景与挑战

脑极体

聊聊 Redis 内存淘汰策略

蘑菇睡不着

Java redis

Dajngo 网站开发 ---Task2(下)

IT蜗壳-Tango

6月日更

HBase 介绍

Alex🐒

HBase

Redis 五种数据结构以及三种高级数据结构解析

蘑菇睡不着

Java redis

(鸡汤文)这一次我终于搞懂了 JavaScript 定时器的 this 指向!

编程三昧

JavaScript 编程 大前端 定时器

Flink Side Outputs

Alex🐒

flink flink1.13

自然语言处理的发展

Qien Z.

自然语言处理 6月日更

超详细Redis数据结构底层实现原理介绍

蘑菇睡不着

Java redis

架构训练营模块六作业

Geek_e0c25c

架构训练营

网络攻防学习笔记 Day50

穿过生命散发芬芳

网络攻防 6月日更

拆分电商系统为微服务——架构师训练营作业六

开拓纪

架构是训练营 作业六

【21-13】PowerShell 运算符

耳东@Erdong

PowerShell 6月日更

优秀中层管理者所具备的特征

石云升

读书笔记 6月日更

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