[转]Spring、struts、webwork2三者MVC的比较

http://juleven.blogdriver.com/juleven/757805.html

Spring、struts、webwork2三者MVC的比较

在web应用方面,Spring有独立的MVC实现,与struts(很久不用了,用的时候版本是1.1)和webwork2相比毫不逊色。

struts缺点是比较重,页面(V)上要有form要用标签,form(M)要继承ActionForm这么个东东,控制类(C)继承Action/DispatchAction。
webwork2比struts要轻,页面没什么说的主要就是标签,model层也不要强制继承什么,控制类还是要实现一些webwork2的接口Action/ModelDriven。
Spring和webwork2轻重相当。页面标签用jstl,model也不用继承什么,控制类继承MultiActionController/SimpleFormController。
struts和webwork2都有自己的标签库,都很强大。不过偶更倾向Spring的选择--JSTL,JSTL是标准的标签库,优点嘛,标准就是优点:)

在页面输入数据绑定上,struts用的是ActionForm的自动绑定,webwork2是modeldriven的getModel()绑定,Spring的是在controller中声明command对象。
这里strus是最重的,页面要用标签,要继承ActionForm,action要对应到form,要有pojo;而webwork2和Spring相对轻一点,webwork2的action要实现ModelDriven接口,Spring要在SimpleFormController的声明中配置一个command对象(或者在代码中显式调用setCommandClass()),然后再有pojo,两者实现代价应该说差不多。

在实现输入验证上struts在form(M)上做文章要继承ValidateForm,webwork2/Spring都在action上做文章。
其中Spring比较特殊,它是编程式的验证;而struts/webwork2都是配置式的验证,在这一点上更倾向struts/webwork2。
即使出现struts/webwork2常规预定义验证不能处理的情况,也可以自己写一些验证规则,而且事实上也写过,当然很少要自己动手写规则:)。
又想起一点来,struts写规则写的是validate-rules.xml文件,而webwork2写的是java类,前者方便后者习惯,选择哪个框架就对哪个框架下手,没什么说的。

这里有一点应该提出来,要用输入验证,页面上必须用标签绑定输入项,这一点三者是一样的。

在国际化上,三者实现类似。

配置文件方面,Spring、struts、webwork2都差不多,难度相当。
Spring一般还要多写一个application.xml来维护DP;struts要多写一个validate-forms.xml(好像是这个文件名,老了,忘了:(),所有要验证的页面都可以在这个文件里配置;webwork2则比较麻烦,要对所有要验证的页面,都写一个对应action的action-validation.xml文件。

其实偶一直认为MVC其中的model部分是比较难办的,如果model层完成全部的业务,就会仅为了MVC而忽略业务部分的分层合理化。
Spring、struts、webwork2三者的MVC都很好的实现了V和C两层,model层的实现相对来说就不那么清晰明确,业务是复杂的本身就应该分层实现。
上面把ValueObject一层划为model其实颇为牵强。

Spring是强大完备的,这从仅仅它的MVC部分就能和struts/webwork2相媲美就能看出来。

说明:“轻”或“重”指的是实现代价实现成本的大小。

备注:上面这些东东来源比较有意思。在CSDN上看见一QQ群的宣传,要先答题才能进去,呵,形式有意思,发了个邮件要了份题目,本来没想做答,不过那QQ群的创建人比较有意思,给回了一个邮件让答一下,呵呵,于是有了上面这些,这是回答的第一个题目。本来他给出了5道题,其他4道题目都是基础性的,虽然甚至更重要一些,但是我都只是用文字描述了一下自己的想法,比较枯燥,就不帖出来了,估计没多少人感兴趣。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值