微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 模拟电路设计 > 对于Struts和Spring两种MVC框架的比较

对于Struts和Spring两种MVC框架的比较

时间:07-30 来源:互联网 点击:
1 引言
基于Web的MVC framework在J2EE的世界内已是空前繁荣。TTS网站上几乎每隔一两个星期就会有新的MVC框架发布。目前比较好的MVC,老牌的有Struts,Webwork。新兴的MVC框架有Spring MVC,Tapestry,JSF等。这些大多是著名团队的作品,另外还有一些边缘团队的作品,也相当出色,如Dinamica,VRaptor等。这些框架都提供了较好的层次分隔能力。在实现良好的MVC分隔的基础上,提供一些现成的辅助类库,同时也促进了生产效率的提高。如何选择一个好的框架应用在项目设计中,将会对项目的效率和可重用具有至关重要性。

2 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组成。基于Stmts构架的Web应用程序基本上符合JSPModel2的设计标准,是MVC设计模式的一种变化类型。根据对framework的描述,很容易理解为什么说Struts是一个Web framwork,而不仅仅是一些标记库的组合。但Struts也包含了丰富的标记库和独立于该框架工作的实用程序类。Struts有其自己的控制器(Controller),同时整合了其他的一些技术去实现模型层(Model)和视图层(View)。在模型层,Struts可以很容易的与数据访问技术相结合,包括EJB,JDBC和Obiect Relation Bridge。在视图层,Struts能够与JSP,VelocityTemplares,XSL等等这些表示层组件相结合。
Struts的体系结构,Struts framework是MVC模式的体现,分别从模型、视图、控制描述struts的体系结构(Architec-ture)。
(1)从视图角度(View)主要由JSP建立,Struts自身包含了一组可扩展的自定义标签库(TagLib),可简化创建用户界面的过程。目前包括:Bean Tags,HTML Tags,Logic Tags,Nested Tags,Template Tags这几个Taglib。有关其详细资料请参考Struts用户手册。
(2)从模型角度(Model) 模型主要是表示一个系统的状态(有时候,改变系统状态的业务逻辑操作也划分到模型中)。在Struts中,系统的状态主要有ActiomForm Bean体现,一般情况下,这些状态是非持久性的。如果需要将这些状态转化为持久性数据存储,Struts本身也提供了Utitle包,可以方便与数据库操作。
(3)从控制器角度(Controller) 在Struts framework中,Controller主要是ActionServlet,但是对于业务逻辑的操作则主要由Action,ActionMapping,ActionForward这几个组件协调完成(也许这几个组件,应该划分到模型中的业务逻辑一块)。其中,Action扮演了真正的业务逻辑的实现者,而ActionMapping和ActionForward则指定了不同业务逻辑或流程的运行方向。
对于Struts如何控制、处理客户请求,通过对Struts的4个核心组件介绍来具体说明。这几个组件是:ActionServlet;Action Classes;Action Mapping(此处包括ActionForward);ActionFrom Bean。

3 Spring框架
Spring实际上是《Expert One―on―One J2EE Design andDevelopment》一书中所阐述的设计思想的具体实现。在One―on一One一书中,Rod Johnson倡导J2EE实用主义的设计思想,并随书提供了一个初步的开发框架实现(interface2l开发包)。而Spring正是这一思想的更全面和具体的体现。RodJohnson在interface21开发包的基础之上,做了进一步的改造和扩充,使其发展为一个更加开放、清晰、全面、高效的开发框架。
Spring是一个开源框架,由Rod Johnson创建并且在其著作《J2EE设计开发编程指南》里进行了描述。它是为了解决企业应用开发的复杂性而创建。Spring使用基本的JavaBeans完成以前只可能由EJB完成的事情变得可能。然而,Spring的用途不仅限于服务器端的开发。从简单性、可测试性和松耦合的角度,任何Java应用都可以从Spting中受益。Spring是一个轻量的控制反转和面向切面的容器框架。这些描述过于简单。但的确概括出Spring。
(1)轻量从大小与开销而言Spting都是轻量的。完整的Spring框架可在一个大小1 MB多的JAR文件里发布。并且Spring所需的处理开销也是微不足道。此外,Spring是非侵入式的:典型地,Spring应用中的对象不依赖于轻量。
(2)控制反转 Spring通过一种称作控制反转(IoC)的技术促进了松耦合。当应用了IoC,对象被动地传递它们的依赖而不是自己创建或者查找依赖对象。可以认为IoC与JNDI相反,不是对象从容器中查找依赖,而是容器在对象初始化时不等被请求就将依赖传递给它。
(3)面向切面Spring包含对面向切面编程的丰富支持,允许通过分离应用的业务逻辑与系统服务(例如审计与事物管理)进行内聚性的开发。应用对象只做它们应该做的,完成业务逻辑,仅此而已。并不负责(甚至是意识)其它的系统关注点,例如日志或事物支持。
(4)容器 Spring包含和管理应用对象的配置和生命周期,在此意义上它是一种容器。可以配置每个bean如何被创建,基于一个配置原形为bean创建一个单独的实例或每次需要时都生成一个新的实例以及它们是如何相互关联的。然而,Spring不应该被混同于传统重量的EJB容器,它们经常是庞大与笨重的,难以使用。
(5)框架Spring使由简单的组件配置和组合复杂的应用成为可能。在Spring中,应用对象被声明式地组合,典型地是在一个XML文件里,Spr4ng提供了很多基础功能(事务管理、持久性框架集成等等),并留有应用逻辑开发。
例如:Spring有3个重点,一个是面向接口编程:一个是控制反转;另外一个就是依赖注入。有了控制反转就有了声明性的bean,在application.xml也就是Spring的核心配置文件里面声明bean的属性,对应的类,引用名称,这些是为编码时要用到的bean做准备的,对应web应用程序,Spring有专门的类SpringContextLoader,等等。另外在web.xml里可以用context-param子节点将application.xml纳入范围,这样容器在加载web应用时,就将对应的bean加载了,剩下的是如何引用这些bean的问题,这里用到Spring的接口注入,也是spring用的最多的依赖注入方式。例如:这有两个类,一个是Main.java,一个是Demo.java.这里Main里面用到了Demo;

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top