参考:
http://wiki.opensymphony.com/display/WW/WebWork+2+Spring+Integration
http://forum.iteye.com/viewtopic.php?t=8509
http://forum.iteye.com/viewtopic.php?t=9939
下载:
http://xwork-optional.dev.java.net/
昨天使用webwork和spring,使用的是SpringObjectFactory方法,突然发现validator没发生作用,折腾半天,
换成external-ref的方法,可以了.但是觉得external-ref的方法太麻烦了.
就是去http://xwork-optional.dev.java.net/下载了一下最新的源码,换回SpringObjectFactory的方式,发现问题解决了(重载getClassInstance解决了这个问题).
于是仔细研究了一下几种组合的方法,根据前面参考中的文章,整理了一下.
看了xwork-optional的源码,发现其实三种方法的源码都包含在这里了,当然也包括external-ref这种方法的源码,只是换了包名和文件名,但是源码基本没变.你可以仔细看看.
1.External-Ref
这种方法看起来比较烦琐,可能现在都改用第3种方法了.
第一步:在web.xml里面增加一个listener,如下
java代码:
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<listener>
<listener-class>com.opensymphony.xwork.spring.SpringExternalReferenceResolverSetupListener</listener-class>
</listener>
第二步:在Spring里面配置类似Dao之类的bean,例如
java代码:
<bean id="myDAO" class="com.ryandaigle.persistence.MyDAO" singleton="true" />
第三步:配置XWork.xml,例如
java代码:
<package name="default" extends="webwork-default"
externalReferenceResolver="com.opensymphony.xwork.spring.SpringExternalReferenceResolver">
<interceptors>
<interceptor name="reference-resolver" class="com.opensymphony.xwork.interceptor.ExternalReferencesInterceptor"/>
<interceptor-stack name="myDefaultWebStack">
<interceptor-ref name="defaultStack"/>
<interceptor-ref name="reference-resolver"/>
</interceptor-stack>
</interceptors>
<default-interceptor-ref name="myDefaultWebStack"/>
<action name="myAction" class="com.ryandaigle.web.actions.MyAction">
<external-ref name="DAO">myDAO</external-ref>
<result name="success" type="dispatcher">
<param name="location">/success.jsp</param>
</result>
</action>
</package>
2.SpringObjectFactory
我一直用这种方法,因为以前觉得是xwork本身提供的方法,升级有保障.
配置方法:
第一步.在spring的 applicationContext.xml (根据实际情况决定) 里面定义你的action,例如
java代码:
<bean name="some-action" class="fully.qualified.class.name" singleton="false">
<property name="someProperty"><ref bean="someOtherBean"/></property>
</bean>
可以看到,可以使用Spring的特性来给你的action设置属性等,当然也可以使用Spring的拦截器等 (可以使用不一定等于推荐使用)
注意一定是singleton="false",因为xwork的action是这样要求的.
第二步.在xwork.xml里定义你的action定义
java代码:
<action name="myAction" class="some-action">
<result name="success">view.jsp</result>
</action>
第三步.要使上面的关联生效,还要用我们的SpringObjectFactory来替换Xwork的默认ObjectFactory.
最新的SpringObjectFactory里面,有两种方法,其中我觉得A方法更直观一些.
A:修改web.xml
java代码:
<!-- 这个是spring的listener,可以改为你的自定义的spring的Listenter -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<!-- 这个必须在 Spring ContextLoaderListener 的后面 -->
<listener>
<listener-class>com.opensymphony.xwork.spring.SpringObjectFactoryListener</listener-class>
</listener>
B.在spring的applicationContext.xml (根据实际情况决定)里面定义一个bean,例如
java代码:
<bean id="spring-object-factory" class="com.opensymphony.xwork.spring.SpringObjectFactory"
init-method="initObjectFactory"/>
这样Spring会自动调用initObjectFactory方法来替换Xwork的默认ObjectFactory
3.ActionAutowiringInterceptor
这个方法是最近出现的,可能是最简洁的方法,但是不知道性能上有没有问题,我觉得jdk1.4以后应该没有任何问题吧,至于实际效果你的自己测试一下.
第一步:配置web.xml
java代码:
<!-- 这个是spring的listener,可以改为你的自定义的spring的Listenter -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
第二步配置xwork.xml里面的拦截器
java代码:
<interceptors>
<interceptor name="autowire" class="com.opensymphony.xwork.spring.interceptor.ActionAutowiringInterceptor">
<param name="autowireStrategy">@org.springframework.beans.factory.config.AutowireCapableBeanFactory@AutowireCapableBeanFactory.AUTOWIRE_BY_TYPE</param>
</interceptor>
<interceptor-stack name="autowireDefault">
<interceptor-ref="autowire" />
<interceptor-ref="defaultStack" />
</interceptor-stack>
</interceptors>
你的拦截器里都要包含autowire,例如这个autowireDefault就相当于以前的默认的拦截器了.
其中的拦截器策略可以配置,上面配置的是根据类型,如果不配置,默认是根据名字.
一共有四种策略:
AUTOWIRE_CONSTRUCTOR
AUTOWIRE_BY_TYPE
AUTOWIRE_BY_NAME
AUTOWIRE_AUTODETECT
这种方法执行原理就是查找你的action的所有字段,如果和Spring的定义bean有相同的,就自动设置.
假设你的Spring的applicationContext.xml里面有这样一个定义:
java代码:
<bean id="userManager" class="com.test.UserManager" />
如果你在xwork.xml 里面定义的某个action有一个字段叫userManager,那么在运行时刻就会自动被设置为Spring的配置文件里定义的Bean.
以上如有不对指出,还请指出
分享到:
相关推荐
16.2 协同使用Spring和WebWork 2/Struts 2 16.3 集成Spring和Tapestry 16.3.1 集成Spring和Tapestry 3 16.3.2 集成Spring和Tapestry 4 16.4 协同使用Spring和JSF 16.4.1 解析JSF管理的属性 16.4.2 解析Spring...
16.2协同使用spring和webwork2/struts2 16.3集成spring和tapestry 16.3.1集成spring和tapestry3 16.3.2集成spring和tapestry4 16.4协同使用spring和jsf 16.4.1解析jsf管理的属性 16.4.2解析springbean 16.4.3...
16.2 协同使用Spring和WebWork 2/Struts 2 16.3 集成Spring和Tapestry 16.3.1 集成Spring和Tapestry 3 16.3.2 集成Spring和Tapestry 4 16.4 协同使用Spring和JSF 16.4.1 解析JSF管理的属性 16.4.2 解析Spring...
结果类型有几种,每种都定义了不同的处理方式: 1. `dispatcher`:这是默认结果类型,通过转发将控制权交给指定的资源,通常是JSP页面。例如: ```xml <result name="success" type="dispatcher">/success.jsp ``...
小结 永远记住:自始至终,实践是学习Java技术历程中极其重要的一环。脱离了实践,是学不好技术的! Java学习、实践之路依然没有银弹,况且一步步走来,要学的东西很多,勤奋是金! 善于利用Internet上众多的资源,多...