深入探讨Spring与Struts的集成方案
Spring是一个轻量级的IoC和AOP容器。它力图简化J2EE开发即J2EE without EJB。Spring为模型层服务层以及表现层都提供了良好的支持和集成方案。
ContextLoadPlugin()负责装载一个Spring应用上下文。(具体的说:是一个WebApplicationContext)。value属性值为要加载的配置Spring受控Bean的xml文件的URI。
3.完成第一种集成方案:实现一个知晓Spring的Action基类。
这种集成方案是从一个公共的能够访问Spring应用上下文的基类中派生所有的Struts Action,但值得庆幸的是:我们不用自己去编写这个知晓Spring应用上下文的基类,因为Spring已经提供了org.springframework.web.struts.ActionSupport:一个org.apache.struts.action.Action的抽象实现。它重载了setServlet()方法以从ContextLoaderPlugin中获取WebapplicationContext。因此,任何时候我们只需要调用super.getBean()方法即可获得一Spring上下文中的一个Bean的引用。
我们再来看一段Action源代码:
|
分析:这个Action类由ActionSupport派生,当CourceAction需要一个Spring受控Bean时:它首先调用基类的getWebApplicationContext()方法以取得一个Spring应用上下文的引用;接着它调用getBean()方法来获取由Spring管理的courceService Bean的一个引用。
小结
至此,我们已经用第一种方案圆满的完成了Spring与Struts的集成工作。这种集成方式的好处在于直观简洁容易上手。除了需要从ActionSupport中派生,以及需要从应用上下文中获取Bean之外,其他都与在非Spring的Struts中编写和配置Action的方法相似。但这种集成方案也有不利的一面。最为显著的是:我们的Action类将直接使用Spring提供的特定类,这样会使我们的Struts Action(即控制层)的代码与Spring紧密耦合在一起。这是我们不情愿看到的。另外,Action类也负责查找由Spring管理的Bean,这违背了反向控制(IoC)的原则。
- 本文关键词:

