有一种方法可以用于Spring与Struts的整合:让Action在程序中手动获得ApplicationContext实例。在这种整合策略下,Struts的Action不接受IoC容器管理,Action的代码与Spring API部分耦合,造成代码污染。
这种策略也有其好处:代码的可读性非常强,Action的代码中显式调用业务逻辑组件,而无需等待容器注入。
Action中访问ApplicationContext有两种方法:
1.利用WebApplicationContextUtils工具类
2.利用ActionSupport支持类
WebApplicationContextUtils可以通过ServletContext获得Spring容器实例。ActionSupport类则提一个更简单的方法:getWebApplicationContext(),该方法用于获取ApplicationContext实例。
Spring扩展了Struts的标准Action类,Spring的Action在Struts的Action后加上Suppport,Spring的Action有如下:
1.ActionSupport。
2.DispatchActionSupport。
3.LookupDispatchActionSupport。
4.MappingDispatchActionSupport。
下面分别给出利用ActionSupport的示例代码:
新的业务控制器,继承Spring的ActionSupport类
public class LoginAction extends ActionSupport { //依然将ValidBean作为成员变量 private ValidBean vb; //构造器,注意:不可在构造器中调用getWebApplicationContext()方法 public LoginAction(){} //完成ValidBean的初始化 public ValidBean getVb(){ return (ValidBean)getWebApplicationContext().getBean("vb"); } //必须重写该核心方法,该方法actionForm将表单的请求参数封装成值对象 public ActionForward execute(ActionMapping mapping, ActionForm form,HttpServletRequest request, HttpServletResponse response)throws Exception { //form由ActionServlet转发请求时创建,包装了所有的请求参数 LoginForm loginForm = (LoginForm)form; //获取username请求参数 String username = loginForm.getUsername(); //获取pass请求参数 String pass = loginForm.getPass(); //下面作服务器端的数据校验 String errMsg = ""; if (username == null || username.equals("")){ errMsg += "您的用户名丢失或没有输入,请重新输入"; }else if(pass == null || pass.equals("")){ errMsg += "您的密码丢失或没有输入,请重新输入"; }else{//如果用户名和密码不为空,才调用业务组件 if (getVb().valid(username,pass)){//vb是业务逻辑组件,通过上面的初始化方法获得 return mapping.findForward("welcome"); }else{ errMsg = "您的用户名和密码不匹配"; } } //判断是否生成了错误信息, if (errMsg != null && !errMsg.equals("")){ //将错误信息保存在request里,则跳转到input对应的forward对象 request.setAttribute("err" , errMsg); return mapping.findForward("input"); }else{//如果没有错误信息,跳转到welcome对应的forward对象 return mapping.findForward("welcome"); } } }
这种整合策略下,表现层的控制器组件不再接受IoC容器管理。因此没有了控制器context,应将原有的action-servlet.xml文件删除,并修改plug-in元素,不要加载该文件。还要修改action配置,将action配置的type元素修改成实际的处理类。这种整合策略也有个好处:代码可读性更强,对传统Struts应用开发的改变很小,容易使用。
将该Action部署在struts-config.xml中,Struts将负责创建该Action。struts-config.xml文件的源代码如下:
<!-- XML文件版本,编码集--> <?xml version="1.0" encoding="gb2312"?> <!-- struts配置文件的文件头,包括dtd等信息--> <!DOCTYPE struts-config PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 1.2//EN" "http://struts.apache.org/dtds/struts-config_1_2.dtd"> <!-- struts配置文件的根元素--> <struts-config> <!-- 配置formbean,所有的formbean都放在form-beans元素里定义--> <form-beans> <!-- 定义了一个formbean,确定formbean名和实现类--> <form-bean name="loginForm" type="lee.LoginForm"/> </form-beans> <!-- 定义action部分,所有的action都放在action-mapping元素里定义--> <action-mappings> <!-- 这里只定义了一个action。action的类型为ActionSuport的子类 --> <action path="/login" type="type="lee.LoginAction" name="loginForm" scope="request" validate="true" input="/login.jsp" > <!-- 定义action内的两个局部forward元素--> <forward name="input" path="/login.jsp"/> <forward name="welcome" path="/welcome.html"/> </action> </action-mappings> <!-- 加载国际化的资源包--> <message-resources parameter="mess"/> <!--- 装载验证的资源文件--> <plug-in className="org.apache.struts.validator.ValidatorPlugIn"> <set-property property="pathnames" value="/WEB-INF/validator-rules.xml,/WEB-INF/validation.xml" /> <set-property property="stopOnFirstError" value="true"/> </plug-in> </struts-config>
此时,Spring无需使用配置Action的配置文件,这种配置方式非常简单。只需要业务逻辑组件的配置文件,业务逻辑组件的配置文件如下:
<?xml version="1.0" encoding="gb2312"?> <!-- 指定Spring 配置文件的dtd> <!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd"> <!-- spring配置文件的根元素 --> <beans> <!-- 配置ValidBean实例--> <bean id="vb" class="lee.ValidBeanImpl"/> </beans>
该配置文件中的业务逻辑组件由于Spring容器负责实现,而ActionSupport能够先定位Spring容器,然后获得容器的业务逻辑组件。
这种整合策略的执行效果与前面两种整合策略的执行效果完全相同。
从代码中分析,在这种整合策略下,业务控制器再次退回到Struts起初的设计:仅由struts-config.xml中Action充当,而避免了像DelegatingActionProxy整合策略的性能低下,因为可以只需要创建实际的Action实例。
这种整合策略的代价是代码污染。
相关推荐
9.1 为什么在Struts 2中使用Spring 196 9.1.1 依赖注入能做些什么 197 9.1.2 Spring如何管理对象和注入依赖 199 9.1.3 使用接口隐藏实现 200 9.2 将Spring添加到Struts 2 202 9.2.1 让Spring管理动作、拦截器和结果...
//第一种方式:使用 Spring 的 ActionSupport 类整合 Structs //第二种方式:使用 Spring 的 DelegatingRequestProcessor 覆盖 Struts 的 RequestProcessor //第三种方式:将 Struts Action 管理委托给 Spring ...
不过,Struts1.x与Struts2的Action模型很大的区别。 Struts2和Struts1.x的差别,最明显的就是Struts2是一个pull-MVC架构。这是什么意思呢?从开发者角度看,就是说需要显示给用户的数据可以直接从Action中获取,而不...
2、action是一个pojo,所以struts2.0与框架的藕合度非常低。 实现Action时有时会继承于ActionSupport, 覆盖execute方法,从而创建一个Action。 因为ActionSupport提供了很多方法可以为开发提供方便。 3、...
主要负责视图(使用struts标签来构建页面视图并且使用ActionSupport来接收并处理页面表单传回来的数据),spring是一个轻量级的容器,他的目标是来实现一个全方位的整合框架,利用spring框架来整合其他子框架,例如...
二,集成 Spring 与 Struts2.1.8.1 1,在web.xml配置监听器(Spring Reference 15.2 Common configuration) <!-- 集成Spring --> <listener-class>org.springframework.web.context.ContextLoaderListener...
10.6.1 使用ActionSupport类整合Struts 177 10.6.2 覆盖RequestProcessor类整合Struts 178 10.6.3 将Action管理委托给Spring框架 180 10.7 Spring整合Hibernate框架 182 10.7.1 创建Hibernate+Spring项目 182 10.7.2...
--3 配置本地化代理工程bean,这是spring整合hibernate的入口 --> <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"> <!--表示在类路径下加载...
{1.4.1}整数与浮点数}{23}{subsection.1.4.1} {1.4.1.1}浮点数原理}{24}{subsubsection.1.4.1.1} {1.4.2}格式化输出浮点数}{24}{subsection.1.4.2} {1.4.3}\texttt {char}}{24}{subsection.1.4.3} {1.4.4}转义...