QCon北京「鸿蒙专场」火热来袭!即刻报名,与创新同行~ 了解详情
写点什么

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

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

关注

评论

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

16. 奇点来临?

Databri_AI

人工智能

基础+缓存雪崩+哨兵+集群+Reids场景设计,经验分享

Java 程序员 后端

读完这份阿里高质量性能优化全解,我的系统终于不再频繁瘫痪了

Java 阿里巴巴 编程 面试 金九银十

人类视觉神经科学助力音视频产业革命 - 弱网下的极限实时通信

声网

音视频 弱网下的极限实时视频通信

☕【JVM技术指南】「理论总结笔记」Java虚拟机垃圾回收认知和调优的"思南(司南)"【上部】

码界西柚

JVM GC 垃圾回收算法 9月日更

成熟的区块链技术是解决供应链金融痛点问题的根本出路

CECBC

网络攻防学习笔记 Day135

穿过生命散发芬芳

网络基础 9月日更

NoSQL数据库——Cassandra

hanaper

译介:《组装一台电脑9:精简》

姬翔

9月日更

JavaScript进阶(上)

Augus

JavaScript 9月日更

网络安全之一个渗透测试小案例

网络安全学海

网络安全 信息安全 渗透测试 WEB安全 安全漏洞

和阿里大牛的技术面谈,springcloud面试题汇集与答案

Java 程序员 后端

想要掌握未来嘛?这份腾讯高工撰写的Redis实战笔记就告诉你什么是未来!

Java 腾讯 面试 大厂 金九银十

FLV格式解析

轻口味

android 音视频 RTMP 9月日更

“融合创新”是区块链的应用发展趋势吗?

CECBC

和腾讯大牛的技术面谈,分布式系统中ACID和CAP有什么区别

Java 程序员 后端

【Vuex 源码学习】第一篇 - Vuex 的基本使用

Brave

源码 vuex 9月日更

Nacos 开源、自研、商业化三位一体战略解读

阿里巴巴中间件

云计算 阿里云 微服务 云原生 nacos

堪比狗血剧!18名Java程序员凭阿里P8笔记,同时斩获大厂offer

Java 编程 面试 阿里 大厂

Rust 与 C++:深入的语言比较

奔着腾讯去

c++ rust 安全 编程语言 并发

和阿里大牛的技术面谈,金三银四旗开得胜

Java 程序员 后端

复盘上次Redis缓存雪崩事故,中级Java工程师面试题

Java 程序员 后端

Kafka 常用工具脚本总结

Se7en

上云迁移之路,如何选择适合方式?

云计算

中国移动5G消息开发者社区第三期直播课堂圆满结束,直播回放已上线社区!

5G消息

和腾讯大佬的技术面谈,BTAJ面试有关散列(哈希)表的面试题详解

Java 程序员 后端

OceanBase 源码解读(四):事务的一生

OceanBase 数据库

数据开发 oceanbase OceanBase 开源 OceanBase 社区版 OceanBase 数据库大赛

MDEX市值机器人系统开发功能介绍

量化系统19942438797

交易所 市值机器人 MDEX

和阿里大牛的技术面谈,字节跳动Java实习面试凉凉经

Java 程序员 后端

关系型数据库如何存储树形结构?

王博

桐乡引入百度智能云开物工业互联网,数字经济再提速

百度大脑

人工智能

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