`
longgangbai
  • 浏览: 7340784 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

比较JSF、Spring MVC、Stripes、Struts 2、Tapestry

阅读更多
【译者按】这是Matt Raible在今年6月24-27号召开的JA-SIG夏季会议上所作的主题演讲,Matt从众多方面对Java Web层框架做了一个全面、深入的比较。笔者认为这是一份及时的文档,它对开发者如何判定一个Web层框架的好坏、如何选择适合自己项目的框架有极大的指导作用。本文是对Matt Raible演讲稿的整理归纳。
【作者介绍】Matt Raible,开源框架AppFuse的发起者、主要开发者;《Professional JSP 2.0》、《Spring Live》等书的作者;众多会议的演讲者,MySQL User Conference, ApacheCon, ApacheCon EU等;现任Raible Designs的CEO。

     首先,Matt以自己的实践经验,指出了Java Web层框架——JSF、Spring MVC、Stripes、Struts 2、Tapestry和Wicket他们各自的优、缺点:
     JSF
     优点:
     Java EE标准,这意味着有很大的市场需求和更多的工作机会
     上手快速并且相对容易
     有大量可用的组件库
     缺点:
     大量的JSP标签
     对REST和安全支持不好
     没有一个统一的实现。既有SUN的实现,又有Apache的实现——MyFaces。

     Spring MVC
     优点:
     对覆盖绑定(overriding binding)、验证(validation)等提供生命周期管理
     与许多表示层技术/框架无缝集成:JSP/JSTL、Tiles、Velocity、FreeMarker、Excel、XSL、PDF等
     便于测试——归功于IoC
     缺点:
     大量的XML配置文件
     太过灵活——没有公共的父控制器
     没有内置的Ajax支持

     Stripes
     优点:
     不需要书写XML配置文件
     良好的学习文档
     社区成员很热心
     缺点:
     社区比较小
     不如其他的项目活跃
     ActionBean里面的URL是硬编码的

     Struts 2
     优点:
     架构简单——易于扩展
     标记库很容易利用FreeMarker或者Velocity来定制
     基于控制器或者基于页面的导航
     缺点:
     文档组织得很差
     对新特征过分关注
     通过Google搜索到的大多是Struts 1.x的文档

     Tapestry
     优点:
     一旦学会它,将极大地提高生产率
     HTML模板——对页面设计师非常有利
     每出一个新版本,都会有大量的创新
     缺点:
     文档过于概念性,不够实用
     学习曲线陡峭
     发行周期长——每年都有较大的升级

     Wicket
     优点:
     对Java开发者有利(不是Web开发者)
     页面和显示绑定紧密
     社区活跃——有来自创建者的支持
     缺点:
     HTML模板和Java代码紧挨着
     需要对OO有较好的理解
     Wicket逻辑——什么都用Java搞定

     接着,Matt通过采访这些框架的作者,与他们讨论各种开源的Java Web框架,并且突出各个框架的长处、听取框架作者对其他框架的看法,希望借此了解这些框架的未来发展方向。

     下列是一些被采访者:
     JSF, Jacob Hookom
     RIFE, Geert Bevin
     Seam, Gavin King
     Spring MVC, Rob Harrop
     Spring Web Flow, Rob Harrop and Keith Donald
     Stripes, Tim Fennell
     Struts 1, Don Brown
     Tapestry, Howard Lewis Ship
     Trails, Chris Nelson
     Struts 2, Patrick Lightbody
     Wicket, Eelco Hillenius

     Matt对采访做了如下总结:
     JSF:
     如果你想让web应用具有类似桌面程序的功能性,那么JSF的标准规范和大量第三方组件库的支持值得你 信赖。
     Spring MVC:
     综合了许多不同的技术,这使得它可以被广泛地应用到不同类型的项目中去;它可以被当作web应用开发的一个基础平台。
     Stripes:
     可以被应用到存在大量复杂数据交互的程序中;有强大的类型转换、绑定和验证功能;可以使管理大的复杂表单以及直接映射它们到域对象变得简单……
     Tapestry:
     在中到大型项目中,表现突出(当然,你也可以只把它应用到单个页面上),在这些项目中,你可以通过简单地创建新的组件起到杠杆作用。
     Struts 2:
     通常更适合于那些希望可以真正开始做事并且愿意花费大量时间来学习他们使用的开源工具的小项目组。Struts 2的目标不是那些更喜欢拖放式开发的“扶手椅程序员”。
     Wicket:
     非常适合于这样的内/外部网应用:UI很复杂并且你希望可以充分利用你的开发者资源。

     上面的总结,基本是突出了各个框架的长处。然而,哪些又是他们不好的地方呢?

     Matt提出了评价一个框架好坏与否的标准:
     Ajax支持        是不是内置了?是否便于使用?
     书签能力       用户能否将某个页面收藏起来并且可以方便地返回到该页面?
     验证        使用是否简单?是否支持客户端(JavaScript)验证?
     可测试性      脱离容器测试控制器,是否足够简单?
     提交和重定向      框架如何处理重复提交问题?
     国际化       如何支持国际化?控制器利用国际化信息,是否容易?
     页面修饰       框架支持哪种类型的页面修饰/组成机制?
     社区和技术支持       提出问题,能否被快速地、恭敬地回答?
     开发工具       是否有支持这个框架的好的工具,尤其是IDE?
     市场需求       学习了这个框架,它能否帮你找到份工作?
     岗位数量       在dice.com和indeed.com上,对这个框架技能的需求如何?

    笔者认为这个评价标准,值得大家借鉴。

     然后,Matt按照这些评价标准,对各个框架做了以下阐述:
     Ajax支持
     JSF:没有内置的Ajax支持,需要使用ICEfaces和Ajax4JSF
     Stripes:没有对应的类库,支持流输出
     Struts 2:内置Dojo,有用于GWT和JSON的插件
     Spring MVC:没有对应的类库,需要使用DWR和Spring MVC扩展
     Tapestry:Tapestry 4.1中,有内置的Dojo
     Wicket:有Dojo和Script.aculo.us支持

     书签能力
     JSF:可以任意提交——URL甚至不被考虑
     Stripes:使用约定,但是你可以不加理会
     Struts 2:有命名空间的概念,这使得收藏某个页面并返回变得容易
     Spring MVC:允许完全的URL控制
     Tapestry:依然存在一些丑陋的URL
     Wicket:允许装配(mount)页面/URL     

     验证
     JSF:默认的国际化信息丑陋,但是配置简单
     Stripes和Wicket:用Java类进行验证——不支持客户端验证
     Struts 2:使用OGNL完成强大的表达式验证功能;只有在Action上指定了规则,才支持客户端验证。
     Spring MVC:允许你使用公共验证器——这是一种成熟的解决方案
     Tapestry:有健壮的验证功能——不需自定义就有漂亮的国际化信息

     可测试性
     Spring MVC和Struts 2:允许利用mocks(例如EasyMock、jMock和Spring Mocks)简单地进行测试
     Tapestry:测试困难,因为页面类被抽象、具体类被简化
     JSF:页面类可以方便地被测试,实际上很像Struts 2 中的actions
     Wicket:有WicketTester——一个强大的解决方案
     Stripes:有Servlet API Mocks和MockRoundtrip

     提交和重定向
     解决重复提交问题的最简单方法是:在提交后重定向
     Spring MVC:允许你将参数加到重定向URL上
     Stripes、Tapestry和Wicket:有“flash式”的支持
     Struts 2:需要一个自定义的解决方案
     JSF:需要一个自定义的解决方案,国际化信息很难加入到页面bean中

     国际化
     JSTL的<fmt:message>标签使国际化变得简单;如何将国际化信息放到控制器类中,还没有一个统一的标准。
     Stripes、Spring MVC和JSF:每个地区使用一个资源绑定文件
     Struts 2、Tapestry和Wicket:提倡把每个页面/action用到的资源文件分开
     JSF:需要在每个页面上定义资源绑定信息
     Tapestry:<span key="key.name">标签比较可怕

     页面修饰
     Tiles能够用于Struts 2、Spring MVC和JSF中;需要对每个页面进行配置。
     SiteMesh能够用于所有的这些框架中(不推荐在JSF、Tapestry或者Wicket中使用);在设置完成后,只需要很少的维护。

     开发工具
     Spring MVC:Spring IDE,但是只做XML校验,不是一个UI/web工具
     Struts 2:Eclipse
     Tapestry:Spindle,对编码者非常有利
     JSF:众多IDE支持,并且做得越来越好
     Stripes和Wicket:没有任何官方工具
     NetBeans目前支持Struts *、JSF(+Facelets)、Tapestry和Wicket,尚不支持Stripes和Spring MVC


    市场需求
    Struts 1:需求依然很大并且被广泛使用
    Spring MVC:越来越受关注,但大部分是因为Spring框架的一些其他特征
    JSF:很快地变得流行起来
    Struts 2:正在获得地盘,但是相关的工作机会很少
    Tapestry:在过去的数年里,受欢迎程度不断增加
    Wicket和Stripes:还是未知数

     通过以上的比较,我想大家对在自己的项目中应该选择哪种Web层框架,应该有了更清醒的认识。

     最后,Matt列出了一些相关资源,也供读者参考。
     Struts - http://struts.apache.org
     StrutsTestCase: http://strutstestcase.sf.net
     Spring MVC - http://www.springframework.org
     Spring IDE: http://www.springide.org
     Gaijin Studio: http://gaijin-studio.sf.net
     Struts 2 - http://opensymphony.org/webwork
     Eclipse Plugin: http://sf.net/projects/eclipsework
IDEA Plugin: http://wiki.opensymphony.com/display/WW/IDEA+Plugin
     Tapestry - http://tapestry.apache.org
     http://spindle.sourceforge.net
     JSF - http://java.sun.com/j2ee/javaserverfaces and http://myfaces.apache.org
     Java Studio Creator: http://sun.com/software/products/jscreator
     MyEclipse: http://myeclipseide.com
     IDEA: http://www.jetbrains.com/idea
     SiteMesh: http://opensymphony.com/sitemesh
     Testing Frameworks
     JUnit: http://junit.org
     EasyMock: http://easymock.org
     jMock: http://jmock.org
     jWebUnit: http://jwebunit.sourceforge.net
     Canoo WebTest: http://webtest.canoo.com
     Tapestry Test Assist: http://howardlewisship.com/blog/2004/05/tapestry-test-assist.html
     AppFuse - http://appfuse.org

     演讲的最后,Matt以一句“If it works, use it!”作为结尾,可谓精辟!

     通过此文,相信大家可以拨开当前Java Web层框架选用上的“迷雾”,见得“月明”了。
     原演讲稿请参见:http://raibledesigns.com/rd/entry/ja_sig_comparing_java_web

<!-- -->
分享到:
评论

相关推荐

    Java Web层框架之比较—比较JSF、Spring MVC、Stripes、Struts 2、Tapestry和Wicket.doc

    本文将深入对比六种流行的Java Web层框架:JSF、Spring MVC、Stripes、Struts 2、Tapestry和Wicket。 **JavaServer Faces (JSF)** JSF作为Java EE的一部分,拥有广泛的支持和市场需求。它的优点在于快速上手和丰富...

    Comparing Web Frameworks; Struts, Spring MVC, WebWork, Tapestry & JSF.pdf

    此软件介绍webwork and struts and jsf的区别

    Struts+Spring+Hibernate+Jsf

    Struts、Spring、Hibernate 和 JavaServer Faces (Jsf) 是Java Web开发中四个非常重要的框架。这四个框架的集成使用可以构建出高效、模块化且易于维护的企业级应用。 Struts 是一个开源的MVC(Model-View-...

    Tapestry,JSF和Struts的比较

    Tapestry、JSF(JavaServer Faces)和Struts都是广泛使用的MVC(Model-View-Controller)框架,它们各自具有独特的特性和优势。下面我们将深入探讨这三个框架的核心概念、优缺点以及适用场景。 首先,Tapestry是由...

    JSF与Spring完美结合

    2. **配置JSF**:为了使JSF能够与Spring协作,需要在JSF的配置文件(如`faces-config.xml`)中添加Spring的JSF监听器`org.springframework.web.jsf.FacesContextListener`,这样JSF就能识别到Spring的Bean。...

    jsf+spring 实例

    此外,Spring MVC是Spring为Web应用提供的一个MVC框架,与JSF有类似的架构模式。 **3. JSF与Spring整合** JSF和Spring的整合主要是通过Spring Web Flow(SWF)或者SpringFaces模块来实现。SWF为JSF提供了更强大的...

    spring mvc 教程

    1. **与Spring MVC深度整合**:Spring Web Flow 2.0不再是独立的框架,而是作为Spring MVC的扩展出现,这意味着开发者可以在同一个项目中混合使用Spring MVC和Spring Web Flow,实现更为灵活的Web应用架构设计。...

    Spring集成Struts、JSF、WebWork2

    而Struts、JSF(JavaServer Faces)和WebWork2则是其他流行的MVC(Model-View-Controller)框架,它们各自有独特的特性和优势。这篇博客"Spring集成Struts、JSF、WebWork2"探讨了如何将这些框架与Spring进行整合,以...

    jsf2+spring sample

    【JSF2与Spring整合详解】 JavaServer Faces 2(简称JSF2)是Java平台上的一个企业级的用户界面框架,它为构建基于Web的应用程序提供了组件化、事件驱动的模型。而Spring框架则是Java后端开发的核心框架,以其依赖...

    JSF SPRING

    jsf与spring的集成的几种方式,以及jsf的一些技术

    JakartaEE Spring MVC

    2. **Controllers**:控制器是Spring MVC中的业务逻辑组件,处理来自前端的请求,执行必要的操作,并将结果返回给视图层。这些控制器可能通过注解(如`@RequestMapping`)进行配置。 3. **Models**:模型对象存储...

    spring3.0MVC中文教材

    - **高度可配置性**: Spring MVC的设计非常灵活,可以轻松地与其他流行Web框架(如Struts、WebWork、JSF和Tapestry)集成,使得开发者可以根据项目的具体需求选择最适合的技术栈。 - **与其他框架的无缝集成**: ...

    JSF和Spring集成.doc

    - **Spring MVC**:Spring MVC 作为 Spring 框架的一部分,可以很好地与 JSF 集成。通过配置,可以实现 JSF 的视图渲染与 Spring 控制器之间的交互。 - **SpringFaces**:这是一个专门用来集成 JSF 和 Spring 的...

    java javaee struts2 spring hibernate免费学习视频教程

    根据提供的标题、描述、标签及部分内容,我们可以总结出以下与Java、Java EE、Struts2、Spring、Hibernate相关的学习知识点: ### Java基础 - **Java语言特性**:介绍Java的基本语法,包括变量、数据类型、流程...

    jsf-spring-4.0.3

    1. **Spring MVC与JSF**:Spring MVC可以作为JSF的后端控制器,处理业务逻辑并返回数据。 2. **依赖注入**:通过Spring的依赖注入,JSF的Managed Beans可以直接引用由Spring管理的Bean,增强代码的可测试性和解耦性...

    JSF Spring hibernate2

    总的来说,"JSF Spring Hibernate2"项目是一个结合了前端展示、后端服务和持久化层的复杂Web应用,它展示了Java技术栈在企业级应用开发中的强大能力。通过深入理解和熟练掌握这些技术,开发者可以构建出高效、稳定且...

    qt.rar_jsf example_jsf spring hibernate_jsf下拉菜单_spring jsf hiber

    JSF是一个用于构建用户界面的MVC框架,它与Spring的结合可以提供更强大的前端控制。Hibernate则是一个对象关系映射(ORM)工具,它简化了数据库操作,使得开发者可以用Java对象的方式来处理数据。 "并有下拉菜单" ...

    jsf-spring-boot-starter-2.2.6.zip

    2. **Spring Boot**:Spring Boot是Spring框架的一个扩展,简化了创建独立的、生产级别的基于Spring的应用程序。它通过自动配置和“起步依赖”使设置过程更加简单,使得开发者能够快速启动新项目。 3. **JSF与...

    [Struts 2权威指南--基于WebWork核心的MVC开发(高清完整版) 1/12

    第10章 Struts 2的标签库,第11章 Struts 2的Ajax支持,第12章 使用FreeMarker充当表现层,第13章 整合Spring,第14章 整合JSF,第15章 整合SiteMesh,第16章 整合JasperReports,第17章 整合JFreeChart,第18章 ...

Global site tag (gtag.js) - Google Analytics