标签:value exe oca cti opera myeclips 区分 host lob
如果每个请求都对应一个Action,就会造成action过多,程序显得比较臃肿,所以可以把一类请求写到一个action中处理,即DispatchAction
在没有使用框架之前,当我们通过一个控制器处理多个请求的时候,我们是通过在URL后面跟上参数来区别不同的操作,比如,下述链接:
http://localhost:8080/UserManager/main?operateId=add&uid=123
http://localhost:8080/UserManager/main?operateId=delete&uid=123
在这里,main是我们的一个控制器,后面我们通过传递operateId参数来让控制器区别不同的操作,那么,在main控制器中,我们可以得到operateId,再根据其不同使用if...else...
语句来分别处理即可。
String operateId = request.getParameter("operateId");
if(operateId.equals("add")){
...
}else if(operateId.equals("delete")){
...
}
同样的,如果我们使用了Struts框架,我们也可以在调用一个Action的时候给它传递参数:(这里假设Action为ManageAction,它的访问路径为/manage
)
http://localhost:8080/UserManager/manage.do?operateId=add&uid=123
然后在这个ManageAction中,也根据operateId的不同来做不同的处理。
Struts框架为了我们处理这种情况,专门提供了DispatchAction,即分派Action。
开发DispatchAction需要继承DispatchAction类,而不是之前的Action类了。
特别要注意的是,这里一定要配置parameter
参数,这个参数也就是我们用来区分不同操作的标志,和1.1中所介绍的一样。那么,这里我仍然使用operateId这个字段。
其实,它和我们之前使用的Action没有太多区别,就是在配置struts-config.xml文件的时候多了一个parameter参数:
<action
parameter="operateId"
path="/manage"
type="com.gavin.struts.action.ManageAction"
validate="false"
cancellable="true" />
不同的地方在于:在ManageAction类中,我们不需要只在一个方法中根据operateId来区分不同的操作了,也就是说,我们不需要写哪些繁琐的if...else...
语句了。我们要做的是针对每一个不同的operateId直接写一个方法,方法的名称就是你的URL链接中指定的operateId名称,这个方法就是将之前的execute
方法改名字即可,参数以及返回值都保持一致。
比如,我们在程序中需要这两种链接:
http://localhost:8080/UserManager/manage.do?operateId=add&uid=123
http://localhost:8080/UserManager/manage.do?operateId=delete&uid=123
那么我们的ManageAction中,就要有add和delete两个方法:
public class ManageAction extends DispatchAction {
public ActionForward add(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response) {
// your code
return null;
}
public ActionForward delete(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response) {
// your code
return null;
}
}
很显然,使用DispatchAction可以使程序条理更加清晰,容易扩展。
【但要注意的是,如果使用DispatchAction,一定要去掉原来的execute方法】
使用动态表单可以更加灵活地使用表单。在某些不能确定表单属性个数和类型的情况下,可以使用动态表单(DynamicForm)来解决问题。
所谓动态表单,其实就是不需要单独写成Java类的表单,使用它只需要在struts-config.xml文件中配置即可。
<form-bean name="userForm" type="org.apache.struts.action.DynaActionForm">
<!-- 该表单的属性是配置出来的 -->
<form-property name="name" type="java.lang.String"/>
<form-property name="password" type="java.lang.String"/>
<form-property name="email" type="java.lang.String"/>
</form-bean>
动态表单的type属性,要写为org.apache.struts.action.DynaActionForm
,同时,它比普通表单多了form-property配置,该配置就是配置表单的属性,由于我们可以在这里动态增减form-property属性的配置,所以称之为动态表单。
另外,它与普通表单获取数据的方式也略有不同:
DynaActionForm userForm = (DynaActionForm) form;
// 从动态表单中取出数据
String name = userForm.getString("name");
String password = userForm.getString("password");
String email = userForm.getString("email");
除此之外,都是相同的。也可以看到,动态表单在使用上更为方便。
我们可以通过MyEclipse工具,自动生成DynamicForm:
全局跳转区别于局部跳转,之前我们在Action中配置的forward字段,都是针对当前Action的跳转,称之为局部跳转:
<action-mappings >
<action
attribute="userForm"
input="/WEB-INF/register.jsp"
name="userForm"
parameter="type"
path="/register"
scope="request"
type="com.gavin.struts.action.RegisterAction" >
<!--局部跳转-->
<forward name="ok" path="/WEB-INF/ok.jsp" />
</action>
</action-mappings>
也就是说,只有对于当前的Action,我们才能够通过”ok”跳转到ok.jsp.
那么,如果我们有一个公共的错误页面error.jsp,所有的Action都可以跳转到该Action,如果一个个地都配置,岂不是很麻烦,所以Struts框架也提供了全局跳转。
使用全局跳转,只需要在struts-config.xml中配置global-forwards即可:
<global-forwards >
<forward name="error" path="/WEB-INF/error.jsp" />
</global-forwards>
所有的Action如果想要跳转到这个错误页面,直接在Action的代码中跳转即可,无需再作其他配置。
使用MyEclipse的工具开发global-forward也很简单:
Struts1.3——DispatchAction、DynamicForm和全局跳转
标签:value exe oca cti opera myeclips 区分 host lob
原文地址:http://www.cnblogs.com/husam/p/7929516.html