Struts VS Spring 两种MVC框架比较

作者:网络 来源:佚名 更新时间:2008-07-07 12:16:38 点击:
  基于web的mvc framework在j2ee的世界内已是空前繁荣。tts网站上几乎每隔一两个星期就会有新的mvc框架发布。目前比较好的mvc,老牌的有struts、webwork。新兴的mvc 框架有spring mvc、tapestry、jsf等。这些大多是著名团队的作品,另外还有一些边缘团队的作品,也相当出色,如dinamica、vraptor等。这些框架都提供了较好的层次分隔能力。在实现良好的mvc 分隔的基础上,通过提供一些现成的辅助类库,同时也促进了生产效率的提高。

  如何选择一个好的框架应用在你的项目中,将会对你的项目的效率和可重用是至关重要的。本文将对目前最流行、最常用的两种framework进行介绍。

  一、struts

  struts是apache软件基金下jakarta项目的一部分。struts框架的主要架构设计和开发者是craig r.mcclanahan。struts 是目前java web mvc框架中不争的王者。经过长达五年的发展,struts已经逐渐成长为一个稳定、成熟的框架,并且占有了mvc框架中最大的市场份额。但是struts某些技术特性上已经落后于新兴的mvc框架。面对spring mvc、webwork2 这些设计更精密,扩展性更强的框架,struts受到了前所未有的挑战。但站在产品开发的角度而言,struts仍然是最稳妥的选择。

  struts有一组相互协作的类(组件)、serlvet以及jsp tag lib组成。基于struts构架的web应用程序基本上符合jsp model2的设计标准,可以说是mvc设计模式的一种变化类型。根据上面对framework的描述,我们很容易理解为什么说struts是一个web framwork,而不仅仅是一些标记库的组合。但 struts 也包含了丰富的标记库和独立于该框架工作的实用程序类。struts有其自己的控制器(controller),同时整合了其他的一些技术去实现模型层(model)和视图层(view)。在模型层,struts可以很容易的与数据访问技术相结合,包括ejb,jdbc和object relation bridge。在视图层,struts能够与jsp, velocity templates,xsl等等这些表示层组件想结合。

  struts的体系结构

  struts framework是mvc 模式的体现,下面我们就从分别从模型、视图、控制来看看struts的体系结构(architecture)。 

  从视图角度(view)

  主要由jsp建立,struts自身包含了一组可扩展的自定义标签库(taglib),可以简化创建用户界面的过程。目前包括:bean tags,html tags,logic tags,nested tags,template tags 这几个taglib。有关它们的详细资料请参考struts用户手册

  从模型角度(model)

  模型主要是表示一个系统的状态(有时候,改变系统状态的业务逻辑操作也也划分到模型中)。在struts中,系统的状态主要有actiomform bean体现,一般情况下,这些状态是非持久性的。如果需要将这些状态转化为持久性数据存储,struts本身也提供了utitle包,可以方便的与数据库操作

  从控制器角度(controller)

  在struts framework中, controller主要是actionservlet,但是对于业务逻辑的操作则主要由action、actionmapping、actionforward这几个组件协调完成(也许这几个组件,应该划分到模型中的业务逻辑一块)。其中,action扮演了真正的业务逻辑的实现者,而actionmapping和actionforward则指定了不同业务逻辑或流程的运行方向。
对于struts 如何控制、处理客户请求,让我们通过对struts的四个核心组件介绍来具体说明。这几个组件就是:actionservlet。action classes,action mapping(此处包括actionforward),actionfrom bean。

  二、spring

  spring 实际上是expert one-on-one j2ee design and development 一书中所阐述的设计思想的具体实现。在one-on-one 一书中,rod johnson 倡导j2ee 实用主义的设计思想,并随书提供了一个初步的开发框架实现(interface21 开发包)。而spring 正是这一思想的更全面和具体的体现。rod johnson 在interface21 开发包的基础之上,进行了进一步的改造和扩充,使其发展为一个更加开放、清晰、全面、高效的开发框架。

  spring是一个开源框架,由rod johnson创建并且在他的著作《j2ee设计开发编程指南》里进行了描述。它是为了解决企业应用开发的复杂性而创建的。spring使使用基本的javabeans来完成以前只可能由ejb完成的事情变得可能了。然而,spring的用途不仅限于服务器端的开发。从简单性、可测试性和松耦合的角度而言,任何java应用都可以从spring中受益。

  简单来说,spring是一个轻量的控制反转和面向切面的容器框架。当然,这个描述有点过于简单。但它的确概括出了spring是做什么的。为了更好地理解spring,让我们分析一下这个描述: 

  1、轻量,从大小与开销两方面而言spring都是轻量的。完整的spring框架可以在一个大小只有1mb多的jar文件里发布。并且spring所需的处理开销也是微不足道的。此外,spring是非侵入式的:典型地,spring应用中的对象不依赖于轻量??从大小与开销两方面而言spring都是轻量的。完整的spring框架可以在一个大小只有1mb多的jar文件里发布。并且spring所需的处理开销也是微不足道的。此外,spring是非侵入式的:典型地,spring应用中的对象不依赖于spring的特定类。

  2、控制反转??spring通过一种称作控制反转(ioc)的技术促进了松耦合。当应用了ioc,对象被动地传递它们的依赖而不是自己创建或者查找依赖对象。你可以认为ioc与jndi相反??不是对象从容器中查找依赖,而是容器在对象初始化时不等被请求就将依赖传递给它。 

  3、面向切面??spring包含对面向切面编程的丰富支持,允许通过分离应用的业务逻辑与系统服务(例如审计与事物管理)进行内聚性的开发。应用对象只做它们应该做的??完成业务逻辑??仅此而已。它们并不负责(甚至是意识)其它的系统关注点,例如日志或事物支持。 

  4、容器??spring包含和管理应用对象的配置和生命周期,在这个意义上它是一种容器。你可以配置你的每个bean如何被创建??基于一个配置原形为你的bean创建一个单独的实例或者每次需要时都生成一个新的实例??以及它们是如何相互关联的。然而,spring不应该被混同于传统的重量的ejb容器,它们经常是庞大与笨重的,难以使用。 

  框架:spring使由简单的组件配置和组合复杂的应用成为可能。在spring中,应用对象被声明式地组合,典型地是在一个xml文件里。spring也提供了很多基础功能(事务管理、持久性框架集成等等),将应用逻辑的开发留给了你。 

  所有spring的这些特征使你能够编写更干净、更可管理、并且更易于测试的代码。它们也为spring中的各种子框架提供了基础。 ,欢迎访问网页设计爱好者web开发。