`

JSF和Struts的区别概述

阅读更多
据说JSF的主要负责人就是struts的主要作者,所以二者的相似点还是有很多的。
都采用taglib来处理表示层:在jsp页面中,二者都是采用一套标记库来处理页面的表示和model层的交互。
二者都采用了bean来作为和jsp页面对应的model层。该model层保存了jsp页面上的数据,同时可以作一些验证工作,在struts中就是FormBean,在JSF中就是back bean。
都 采用bean作为控制层,Struts中采用ActionBean来处理业务逻辑,对于简单的应用可以直接在ActionBean中编写业务逻辑代码,也 可以调用另外的bean或者EJB来处理业务逻辑;对于JSF则采用backing bean来处理业务逻辑,同样,backing bean也可以直接编写业务逻辑或者调用其他的bean来处理业务逻辑。
都采用xml配置文件来处理bean的配置,页面导航等问题,增加了系统的灵活性。
都采用资源文件来处理国际化和本地化的问题。
然而,二者的不同点也很多,下面分别说明:
首 先二者的侧重点不同,Struts侧重于控制层,侧重于如何分派和处理用户的请求,所以表示层的taglib功能不够强大。而JSF则侧重于表示层,实现 了大量的标准组件,允许开发人员对表示层有更多的控制权,同时JSF实现了一个开放的架构,允许开发人员创建自己的组件,或者在现有的组件上继承,开发功 能更强大的组件。本人认为这是JSF最大的一个特色。(有点类似于vcl和.net组件)
和jsp 对应的model层,在Struts中采用FormBean来保存用户输入的数据,基本上一般字段的类型都是String。而且可以进行简单的验证,当然 如果采用动态的FormBean就不能在FormBean中进行验证了。在Struts中,jsp和FormBean是紧密结合在一起的,只要写一个 jsp就必须对应一个FormBean,同时jsp上的每个组件都对应FormBean中相同名字的字段。本人认为这里不太灵活,比如,开发页面的时候就 必须考虑后台的FormBean的实现,但此时如果该页面没有FormBean的化则程序运行时会出错。在JSF中,JSP页面中的组件通过value属 性和backing bean的字段关联,这样就有比较大的灵活性,页面上的每个组件可以对应相同的backing bean,也可以对应不同的backing bean(当然本人认为在一般的应用中,一个页面上的组件还是都对应到一个backing bean较好),而且在设计页面的时候可以不考虑backing bean如何设计,可以在设计完页面之后再考虑backing bean的实现问题。
关于数据验证,Struts可以采用在FormBean中的验证函数中进 行验证,也可以使用validator进行验证(关于这种验证方法,本人没有测试过,不知效果如何,希望有经验的朋友指教!)。在JSF中,提供了一些标 准的validator。可以对输入的数据做一些简单的验证,例如验证数值数据的范围,字段是否必填等。但其验证的反馈信息为英文。如果该信息不能自定义 的化,那么针对国内的应用就不太适合了,目前本人还没有找到该反馈信息是否能够自定义的办法。另外对于input类型的组件可以通过validator属 性关联到backing bean的一个验证方法上。在事件处理方法中进行验证也是一个办法。
在JSF中还有一个问题就是在JSF生成的页面 中,组件的Id命名比较怪异,所有的组件的id都类似于“form:compnentid”即form的名称+“:” +组件的id。这样通过javascript访问组件就不是很方便,通过form.id形式好像不能访问到组件。不知道各位有没有好的解决方案。                                                                         
控制层:Struts 中通过form的action来提交请求,通过ActionServlet来分发请求,最后由ActionBean来处理请求,在Action中实现业务 逻辑或者调用其他的业务逻辑bean来完成用户的请求并返回客户端。在这里,一个form只有一个action,即一个页面只能提交到一个action Bean。对于页面上有多个按钮都需要提交的情况就需要使用一些变通的方法了。和传统的web开发的模式比较接近。
对于JSF,采用了事件模 式来处理用户提交的请求。JSF实现了事件监听器来监测事件,例如当用户单击了一个按钮就会触发一个按钮单击事件,还有valuechange事件监听器 来监测数值改变的事件等。例如在页面中通过通过CommandButton按钮的action属性来关联到backing bean的方法来执行相应的操作。 每个不同的按钮都可以关联不同的方法,当然也可以关联相同的方法(这样就和Action Bean非常类似了)。这中开发模式比较接近于传统的c/s模式或者Asp.net的开发模式。对于那些从c/s架构程序或者Asp.net架构转过来的 开发者来说,这种方式可能更自然一些。
在JSF的一些简单的示例程序中,通常把和jsp对应的model层和jsp所提交的action放在 同一个backing bean中,即业务逻辑和业务逻辑所处理的数据在同一个bean中。本人认为,这样的结构只能用在简单的应用中,对于企业级的开发并不适合。应该将页面所 关联的数据和页面所做的action分开,这样的结构更好一些,比较类似于struts的结构。
JSF的backing bean中的方法访问session,request等没有struts中的直观。笔者找了很多例子才知道如何访问session中的数据。
页 面的导航:关于页面的导航,struts和JSF比较类似。都是在xml的配置文件中配置导航规则。每个要跳转的页面都有一个别名,在程序中通过别名进行 跳转。另外Struts中的跳转是在ActionBean中发生,execute方法最后返回一个actionForward来进行跳转。而JSF则在事 件处理方法中最后返回一个字符串,由系统在xml文件中匹配自动进行跳转。在JSF中也可以通过在JSP页面的CommandButton的action 属性中直接填写跳转的别名直接跳转,而不必经过事件处理方法的处理。
资 源文件的管理:Struts和JSF对于资源文件的管理比较类似,Struts中在struts-config.xml中对资源文件进行配置,实现整个程 序的统一管理。而对于JSF则可以在每个JSP页面中分别定义资源文件,然后通过资源文件的别名来访问资源文件中的内容。两者的格式也不相同,在 Struts中,格式为: grade1.grade2.grade3 = your information,通过“.”来表示级别。而在JSF中则必须通过下划线来表示级别,例如grade1_grade2_grade3= your information。本人认为还是struts的方案更直观一些。另外在Struts的资源文件中可以定义信息的显示格式,例如: error.header,error.footer。而JSF中如何定义还不太清楚,或者可以通过定义Messages标记的属性来定义。 
  也就是说,struts和JSF是互补的,而不是竞争对手.JSF看来是要和.net抗衡的,听说struts2.0要集成JSF.
本文出自 51CTO.COM技术博客
分享到:
评论

相关推荐

    基于J2EE下的JSF与Struts框架比较分析

    Apache Struts 和 JavaServer Faces (JSF) 是两种广受欢迎的开源Web应用框架。Struts 作为早期的框架,基于MVC(Model-View-Controller)设计模式,已经在业界获得了广泛的认可。而JSF作为一种相对较新的框架,旨在...

    JSF与Struts的异同.rar

    Struts概述** Struts是Apache软件基金会的一个开源项目,是早期MVC框架的代表。它强调了控制层的分离,通过Action类来处理用户请求。 **Struts的特点:** - **Action和ActionForm:**Struts通过Action类处理业务...

    MVC模式JSF与Struts的异同.txt

    #### 三、JSF与Struts的主要区别 ##### 1. 架构差异 - **Struts架构**:依赖于Servlet容器,使用Action作为控制器,通过ActionForm收集表单数据,并利用`struts-config.xml`进行配置管理。 - **JSF架构**:更加...

    Struts2整合JSF

    通过上述讲解,我们了解到Struts2整合JSF能够提升Web应用的开发效率和功能,但同时也需要开发者具备扎实的Struts2和JSF基础。实践中,可以借助书中的案例和提供的源代码,逐步掌握这一整合技术。

    JSF从零进阶

    - **与Struts的关系**:虽然JSF和Struts都是基于MVC架构的,但它们之间存在显著差异。JSF提供了更多的灵活性和选择性,比如页面设计者可以根据需要选择不同的组件,而应用开发者无需关心具体的实现细节。 - **兼容...

    JSF开发介绍

    尽管JSF和Struts都遵循MVC模式,但它们在架构和实现上存在显著差异。Struts更依赖于配置文件和自定义的Action类,而JSF则采用了更加面向组件的方法,允许将Action绑定在Managed Bean中,无需额外的配置。此外,JSF...

    JSF课件 jsf介绍

    ### JSF介绍与技术概述 #### 一、JSF概览 JSF(JavaServer Faces)是一种基于Java的标准Web应用程序框架,它为开发者提供了一种简单的方式来构建动态且交互式的Web应用。本节将深入探讨JSF的核心概念、特点以及与...

    JSF 生命周期 实例详解

    例如,Struts需要手动处理表单bean和动作,而JSF允许直接将UI组件与JavaBean属性绑定,实现数据的自动同步。JSF的这种特性减少了手动编写代码的工作量,使得开发更高效,同时也更易于维护。 **自动服务器端视图管理...

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

    第1章 Struts 2概述,第2章 Struts 2下的HelloWorld,第3章 Struts 2基础,第4章 深入Struts 2,第5章 Struts 2的类型转换,第6章 文件的上传和下载.,第7章 Struts 2的拦截器,第8章 Struts 2的输入校验,9.2 ...

    JavaServer Faces 2.0完全参考手册(JSF2.0中文版) 1/2

    在这本权威著作中,sun microsystems公司中的jsf合作规范领导者展示了如何创建动态的、跨浏览器的web应用程序,由于保留了较高质量的代码和可扩展性,这些应用程序可以给用户带来极为优秀的体验。 《JavaServer ...

    JSF+Spring+JPA(Hibernate实现)的环境搭建

    - **JSF**:作为Java EE的一部分,JSF更符合企业级应用开发的标准和规范,提供了丰富的组件库和事件驱动机制,使得前端界面的开发更加便捷高效。 - **Struts2**:虽然功能强大且灵活度高,但其并不是Java EE标准的一...

    JSF is import

    本文旨在深入解析JSF的核心特性和优势,探讨其与传统UI构建技术的区别,并分析JSF在J2EE环境下的应用价值。 #### JavaServer Faces (JSF) 技术概述 ##### JSF技术简介 JSF是一种基于Java的框架,用于构建企业级...

    seam jsf ejb 资源相关连部分

    Seam、JSF(JavaServer Faces)和EJB(Enterprise JavaBeans)都是Java企业级开发的重要组成部分,它们各自解决了不同的问题,并且可以很好地协同工作来构建复杂的企业级应用。 #### 二、JSF简介 JSF是一个基于组件...

    jsf标签使用文档

    #### 一、JSF概述与标签使用 JavaServer Faces(简称JSF)是一种基于Java EE的标准技术,它主要用于构建企业级Web应用。JSF提供了丰富的功能,包括表单处理、验证、国际化等,并通过一套强大的组件模型支持网页组件...

    Struts 2框架

    ### Struts 2框架概述 #### 一、Struts 2框架与Struts 1框架的主要差异 在探讨Struts 2框架之前,我们先来理解一下它与Struts 1框架之间的主要区别。这两代框架尽管名字相似,但在设计理念和技术实现上却存在显著...

    <Struts Web设计与开发大全>电子版

    ### Struts Web设计与开发大全知识点总结 ...通过以上内容,本书不仅提供了丰富的理论知识,还通过实例详细讲解了Struts框架的实际应用,非常适合初学者和有一定Java Web开发经验的人士参考学习。

    Struts2入门教程

    知识点一:Struts2框架概述 Struts2是一个优秀的Web框架,它以Webwork的设计思想为核心,并且融合了Struts1的优点。因此,Struts2实际上是Struts1和Webwork的结合产物。由于其优秀的设计,越来越多的开发人员开始...

    JSF教程国外大学的一个课件 Servlet+JSP-Review

    这些课程不仅覆盖了基本的Servlet和JSP知识,还涉及到了更高级的主题,如Struts、JSF、Ajax等。 #### 五、结语 通过本教程的学习,开发者不仅能够掌握Servlet和JSP的基础知识,还能了解到如何使用这些技术来构建...

Global site tag (gtag.js) - Google Analytics