一直在用Webwork2,因为Struts2基于Xwork2开发,变化更多的体现在名称上,所以平时甚少关注。这些天看了一下Apache上的文档,觉得Struts2更加优雅一些,至少Action变成了一个纯粹的POJO,而无须再实现任何一个接口。
   
    Struts2不再提供Webwork2内置的IoC容器支持,转而将Spring作为ObjectFactory的缺省实现。所有由Struts2创建的对象都是由ObjectFactory实例化,ObjectFactory可以集成各种IoC容器,例如Spring、Pico、 Plexus等等。


    
    在******方面,Struts2不再支持AroundInterceptor,如果要用到AroundInterceptor ,则必须单独引入Webwork2的相关类,或者重写自己的******.这一点是我不太理解的地方,不知出于什么考虑。
   
    Struts2全面引入了Dojo,大概是对以前Webwork2在客户端实现的不满吧。例如不再支持Webwork2的richtexteditor,而以Dojo的编辑器取代。说实话,Webwork2了的rich text编辑器确实不太好用,有不少bug.还把Webwork2的Datepicker标签换成了Dojo实现的datetimepicker标签。
   
    对开发人员而言,Struts2在Action映射方面的改进值得关注,尤其是借鉴了Spring的方式,提供了对action名称通配符的支持。在Webwork2里,需要在xwork.xml里以如下格式定义action:
   
    <action name=“Logon” class=“tutorial.Logon”>
   
    <result type=“redirectAction”>Menu</result>
   
    <result name=“input”>/Logon.jsp</result>
   
    </action>
   
    而在Struts2中,则可以引入通配符,形如:
   
    <action name=“*Logon” class=“tutorial.Logon”>
   
    <result type=“redirectAction”>Menu</result>
   
    <result name=“input”>/Logon.jsp</result>
   
    </action>
   
    这样,任何以Logon结尾用作登录验证的Action,例如NewUserLogon,都可调用tutorial.Logon的一个实例。
   
    Struts2还引入一个消息存储******MessageStoreInterceptor用于存放、检索各种提示、错误消息等等,在一个session生命期中都是可用的。
   
    总的来说,Struts2与Webwork2的区别不是很大,但如果将现有的Webwork2项目整体迁移到Struts2上,还是需要认真考虑一下。