四、让spring接管我们的struts(action控件)

  • 首先我们在struts-config.xml中配置叫做代理请求   DelegatingRequestProcessor在org.springframework.web.struts下就是让spring接管struts

<!-- 配置代理请求处理 DelegatingRequestProcessor ,它的用处是 -->
    <controller>
     <set-property property="processorClass" value="org.springframework.web.struts.DelegatingRequestProcessor"/>
    </controller>ssh之雇员管理系统(5)-将struts+spring整合2_xml

如图所示配置前的时候是找action对应的type=com.hsp.web.action.LoginAction,配置后的话我们就得向spring容器中找这个action啦。

  • 在spring中配置这个action,这个时候就是把LoginAction.java看成是bean,因为在spring中的配置,几乎是bean的配置啊。
<!-- 配置action -->
<bean name="/login" class="com.wang.web.action.LoginAction" />

           这个时候我们就可以可以将struts-config.xml中的/login中的type=type=com.hsp.web.action.LoginAction给去掉啦,因为他会找到spring中的action,这里name必须和struts-config.xml的相同。这我们就可以通过spring容器来获取action,和配置action的一些属性

  • 这个时候呢我们的LoginAction.java中就可以省略很多不必要的东西
package com.wang.web.action;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionForward;
import org.apache.struts.action.ActionMapping;
import org.apache.struts.actions.DispatchAction;
import org.springframework.web.context.WebApplicationContext;
import org.springframework.web.context.support.WebApplicationContextUtils;

import com.wang.domain.Employee;
import com.wang.service.interfaces.EmployeeServiceInter;
import com.wang.web.form.EmployeeForm;

public class LoginAction extends DispatchAction {

/**
* 当一个请求发来时次方法将被执行
*/
EmployeeServiceInter employeeServiceInter; //我们在此处定义出接口EmployeeServiceInter ,下面去实现他的set方法,这里的
employeeServiceInter要与ApplicationContext中配置的action的属性中的name值相同。
//在调用时候action时候,spring就会将这个employeeServiceInter添加给此处的set方法啦 
public void setEmployeeServiceInter(EmployeeServiceInter employeeServiceInter) {
  System.out.println("setEmployeeServiceInter方法被调用");
   this.employeeServiceInter = employeeServiceInter;
}

public ActionForward login(ActionMapping map, ActionForm form, HttpServletRequest request, HttpServletResponse response)
throws Exception {
//下面这段话既可以代替ApplicationContext ac = new AplicationContext("xxx.xml");
// WebApplicationContext ctx = // WebApplicationContextUtils.getWebApplicationContext
// (this.getServlet().getServletContext()); //得到验证的bean,由于是面向接口编程,所以我们用到接口
//由于我们把这个LoginAction看成是bean,而且也在ApplicationContext中配置啦,那下面这句话就是为得到这个
employeeService的bean,那我们在ApplicationContext中呢就可以配置action的属性,
让这个属性的ref为employeeService

EmployeeServiceInter employeeServiceInter = (EmployeeServiceInter)ctx.getBean("employeeService");

//通过ActionForm,获取表单的值
EmployeeForm employeeForm = (EmployeeForm) form;
Employee e = new Employee();

//从表单中获取值,set到Employee中
e.setId(Integer.parseInt(employeeForm.getId()));
e.setPwd(employeeForm.getPwd());

//通过逻辑去验证
e = employeeServiceInter.vlidateEmployee(e);
if(e !=null){
//e不为空,把雇员e添加到session中便于页面用到
request.getSession().setAttribute("loginuser", e);
return map.findForward("ok");
}else {
return map.findForward("err");
}
}

public ActionForward loginout(ActionMapping map, ActionForm form,
HttpServletRequest request, HttpServletResponse response) throws Exception {
// TODO Auto-generated method stub
return super.execute(map,form,request,response);
}
}

现在我们在ApplicationContext.xml中配置action的属性啦,让他的属性的ref指向employeeService。

<!-- 配置action -->
<bean name="/login" class="com.wang.web.action.LoginAction" >
<property name="employeeServiceInter" ref="employeeService"></property>
</bean>

那在LoginAction中的那句话EmployeeServiceInter employeeServiceInter = (EmployeeServiceInter)ctx.getBean("employeeService");就可以不用啦。




  • 通过使用sping来接管我们的action,还有一个好处,可以解决action 是单例的问题.通过在applicationContext.xml文件中配置属性    <bean scope=”singlton/prototype/request/sesssion/global session”/>  那ApplicationContext.xml中配置action就变为下面的形式
<!-- 配置action -->
<bean name="/login" scope="prototype" class="com.wang.web.action.LoginAction" >
<property name="employeeServiceInter" ref="employeeService"></property>
</bean>

 

 



作者:少帅

您的支持是对博主最大的鼓励,感谢您的认真阅读。

本文版权归作者所有,欢迎转载,但请保留该声明。