2天时间,聊今年最热的 Agent、上下文工程、AI 产品创新等话题。2025 年最后一场~ 了解详情
写点什么

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

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

关注

评论

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

探究Spring中Bean的线程安全性问题

Java spring 线程安全 bean

程序员必知必会!阿里内部热捧“Spring全线笔记”太完整了

程序知音

Java spring java架构 Java进阶 后端技术

三顾茅庐,七面阿里,终拿25k*16offer,我的面试历程

程序知音

Java 后端 java面试 Java进阶 Java面试八股文

深入理解 slab cache 内存分配全链路实现

bin的技术小屋

内存管理 Linux Kenel 内存池 slab

vivo积分任务体系的架构演进-平台产品系列05

vivo互联网技术

架构演进 积分 任务体系

瓴羊Quick BI工具重建企业数字体系,数据处理不再难

巷子

细节!3部分讲明白HotSpot:运行时+编译器+垃圾回收器

Java JVM 虚拟机 hotspot

RocketMQ消费者是如何负载均衡的

华为云开发者联盟

开发 华为云 华为云开发者联盟 企业号 5 月 PK 榜

人工智能大模型这场游戏才刚刚开始吗?还是在走下坡路? | 社区征文

迷彩

AI大模型 大模型时代 三周年征文 三周年连更

单点登录实现思路和方案

Java 单点登录

牛掰!阿里人用7部分讲明白百亿级高并发系统(全彩版小册开源)

Java 系统设计 高并发

Java泛型详解

timerring

Java

深扒!阿里人用6部分讲完Java性能调优:多线程+设计模式+数据库

Java 性能优化 性能调优

解密Elasticsearch:深入探究这款搜索和分析引擎 | 京东云技术团队

京东科技开发者

elasticsearch redis 底层原理 企业号 5 月 PK 榜 画像系统

新手必看|StarRocks 入门教程来啦!

StarRocks

数据库 大数据 数据湖 OLAP 数仓

FFmpeg从入门到精通-云享读书会总结

DS小龙哥

三周年连更

一起单测引起的项目加载失败惨案 | 京东云技术团队

京东科技开发者

spring 单元测试 bean 企业号 5 月 PK 榜 Javaassist

腾讯云大佬亲码“redis深度笔记”无废话全精华!

程序知音

Java 数据库 redis Java进阶 后端技术

火山引擎DataTester上线全新MAB智能调优实验

字节跳动数据平台

AB testing实战 A/B测试 企业号 5 月 PK 榜

ShareSDK Facebook平台注册指南

MobTech袤博科技

手把手教会你 | 多用户-服务器聊天室应用软件开发

TiAmo

多线程并发 数据库编程 服务器聊天室

面向万物智联的应用框架的思考和探索(中)

HarmonyOS开发者

限量!腾讯高工用4部分讲清楚了Spring全家桶+微服务

Java spring 微服务 Spring Cloud Spring Boot

如何在Github参与开源项目的建设

骑牛上青山

GitHub 开源 PR

java 中为什么有了 spring 还再来个 springboot?

海拥(haiyong.site)

三周年连更

扒去Spring事件监听机制的外衣,竟然是观察者模式

Java spring 设计模式 观察者模式 事件监听

如何维护好TiDB的三颗仙丹——索引、SQL和IO

TiDB 社区干货传送门

数据库架构设计

TiDB 在 IPv6 的 K8S 和物理机环境的部署

TiDB 社区干货传送门

安装 & 部署 数据库架构选型 数据库前沿趋势

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