一、需要的JAR文件为:Spring和Struts2框架本身需要的JAR文件以及他们所依赖的JAR文件,比如commons-logging.jar等等,另外还需要Struts2发布包中的struts2-spring-plugin-x.xx.jar。
二、在web.xml中增加WebApplicationContext的相应配置,以下两种配置方式本质是一样的。
1. Servlet 2.3及以上版本可以使用监听器,相应配置如下:
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/classes/applicationContext.xml</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
如果spring配置文件被命名为applicationContext.xml,并且放在WEB-INF目录下,则不需要配置<context-param>,因为ContextLoaderListener默认在WEB-INF目录下寻找名为applicationContext.xml的文件。若存在多个Spring配置文件,则在<param-value>中依次列出,之间以逗号隔开。
2. Servlet 2.3以下版本由于不支持<listener>,需要配置<servlet>,格式如下:
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/classes/applicationContext.xml</param-value>
</context-param>
<servlet>
<servlet-name>contextLoaderServlet</servlet-name>
<servlet-class>org.springframework.web.context.ContextLoaderServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
如果spring配置文件被命名为applicationContext.xml,并且放在WEB-INF目录下,则不需要配置<context-param>,因为ContextLoaderListener默认在WEB-INF目录下寻找名为applicationContext.xml的文件,或者是名字为contextConfigLocation的ServletContext参数所指定的文件。由于该Servlet配置只是为了在容器启动时能启动ContextLoaderServlet使其工作,而不需要引用该Servlet,所以不需要配置<servlet-mapping>。
三、
在
web.xml
中完成加载
WebApplicationContext
之后,接下来就可以做到
Spring
和
Struts2
的整合了。整合有两种方法,分别叙述如下:
1、 将Struts的业务逻辑控制器类配置在Spring的配置文件中,业务逻辑控制器中引用的业务类一并注入。注意,必须将业务逻辑控制器类配置为scope=”prototype”!
1)在struts.xml文件中加入 < constant name="struts.objectFactory" value="spring" />
指struts.objectFactory为spring,struts2框架就会将Bean转发给Spring来创建,装配,注入。但是Bean创建完成之后,还是由struts2容器来管理其生命周期。
还可以就是在src下建立一个struts.properties文件,写入: struts.objectFactory=spring
这是另一种方式,如果是这样子创建就不用在struts.xml文件中指定,struts.xml也不用更改,如常一样,如果在Action中有依赖于其它的Bean,也会被自动注入.这个时候,Action实例是以prototype方式创建的,Spring会为每个请求创建一个action的实例。
2)
在某些时候,你可能希望不仅仅让SPRING创建和装配Action对象,还希望让SPRING完全管理这些对象,如希望使用AOP或者希望使用acegi时。这时候,只需要在spring的配置文件中定义这些action 即可。
如在applicationContext.xml文件中: < bean id="user" class="action.LoginAction"/>
然后在struts.xml文件中的action元素,class="user"即可。如下:
<
action
name
="login"
class
="user"
method
="login"
>
<
result
name
="success"
>
/success.jsp
</
result
>
<
result
name
="error"
>
/error.jsp
</
result
>
</
action
>
需要注意的一个地方:Spring中的缺省作用域是单例。而往往Action属于有状态的Bean,应该使用prototype作用域。
< bean id="user" class="action.LoginAction" singleton="false"/> 如果忽略了这个细节,在我们实用SET,GET 方法注入关系的时候可能会有线程安全上的风险。请注意!
2、 第二种实现方法:
1) 业务类在Spring配置文件中配置,业务逻辑控制器类不需要配置,Struts2的Action像没有整合Spring之前一样配置,<action>的class属性指定业务逻辑控制器类的全限定名。
2) 业务逻辑控制器类中引用的业务类不需要自己去初始化,Struts2的Spring插件会使用bean的自动装配将业务类注入进来,其实业务逻辑控制器也不是Struts2创建的,而是Struts2的Spring插件创建的。默认情况下,插件使用by name的方式装配,可以通过增加Struts2常量来修改匹配方式:设置方式为:struts.objectFactory.spring.autoWire = typeName,可选的装配参数如下:
a)
name:等价于Spring配置中的autowire=”byName”,这是
缺省值。
b)
type:等价于Spring配置中的autowire=”byType”。
c)
auto:等价于Spring配置中的autowire=”autodetect”。
d)
constructor:等价于Spring配置中的autowire=” constructor”。
四、如果原先在Struts2中使用了多个object factory,则需要通过Struts2常量显式指定object factory,方式如下:struts.objectFactory = spring;如果没有使用多个object factory,这一步可以省略。
五、可以通过设增加Struts2常量来指定是否使用Spring自身的类缓存机制。可以设定的值为true或false,默认为true。设置方式为:struts.objectFactory.spring.useClassCache = false。
六、至此,完成了两种方式的整合。比较这两种整合方式,其本质是一样的。不同之处在于,使用第二种自动装配的方式时,由于没有在Spring中配置业务逻辑控制器,所以需要对其配置一些AOP之类的内容时就很难实现了。