Struts1.3——DispatchAction、DynamicForm和全局跳转
1.DispatchAction-分派Action
1.1 为什么需要DispatchAction
如果每个请求都对应一个Action,就会造成action过多,程序显得比较臃肿,所以可以把一类请求写到一个action中处理,即DispatchAction
在没有使用框架之前,当我们通过一个控制器处理多个请求的时候,我们是通过在URL后面跟上参数来区别不同的操作,比如,下述链接:
http://localhost:8080/UserManager/main?operateId=add&uid=123http://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")){
...
}
- 1
- 2
- 3
- 4
- 5
- 6
同样的,如果我们使用了Struts框架,我们也可以在调用一个Action的时候给它传递参数:(这里假设Action为ManageAction,它的访问路径为/manage)
http://localhost:8080/UserManager/manage.do?operateId=add&uid=123
然后在这个ManageAction中,也根据operateId的不同来做不同的处理。
1.2 开发和配置DispatchAction
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" />
- 1
- 2
- 3
- 4
- 5
- 6
不同的地方在于:在ManageAction类中,我们不需要只在一个方法中根据operateId来区分不同的操作了,也就是说,我们不需要写哪些繁琐的if...else...语句了。我们要做的是针对每一个不同的operateId直接写一个方法,方法的名称就是你的URL链接中指定的operateId名称,这个方法就是将之前的execute方法改名字即可,参数以及返回值都保持一致。
比如,我们在程序中需要这两种链接:
http://localhost:8080/UserManager/manage.do?operateId=add&uid=123http://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;
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
很显然,使用DispatchAction可以使程序条理更加清晰,容易扩展。
【但要注意的是,如果使用DispatchAction,一定要去掉原来的execute方法】
2.DynamicForm-动态表单
使用动态表单可以更加灵活地使用表单。在某些不能确定表单属性个数和类型的情况下,可以使用动态表单(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>
- 1
- 2
- 3
- 4
- 5
- 6
动态表单的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");
- 1
- 2
- 3
- 4
- 5
除此之外,都是相同的。也可以看到,动态表单在使用上更为方便。
我们可以通过MyEclipse工具,自动生成DynamicForm:
3.全局跳转
全局跳转区别于局部跳转,之前我们在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>
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
也就是说,只有对于当前的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>
- 1
- 2
- 3
所有的Action如果想要跳转到这个错误页面,直接在Action的代码中跳转即可,无需再作其他配置。
使用MyEclipse的工具开发global-forward也很简单:
Struts1.3——DispatchAction、DynamicForm和全局跳转的更多相关文章
- Struts2的动态Action和全局跳转视图以及配置各项默认值
1:Struts2的默认访问后缀是.action(特别需要注意的是改了配置文件web.xml或者struts.xml需要重启服务器) 2:Struts2中常用的常量介绍:<!-- 一:全局配置 ...
- Struts全局跳转
1.在struts配置文件中配置一个全局跳转 2.然后关联一个jsp文件 4.关联好以后会出现如图所示页面 在代码中会有如图所示的代码增加 5.然后再action中设置跳转
- struts1.3中使用DispatchAction的一个问题
近期做项目发现我们公司的项目是用struts1写的,在多方百度下,总有理解了struts1.3的DispatchAction的使用方法 一:struts.xml文件的配置 <?xml versi ...
- struts1
1.简单应用示例 导入struts1的jar包,然后配置xml,写java和jsp /struts/WebRoot/Login.jsp <%@ page language="java& ...
- J2EE学习篇之--Struts1详解
今天来看一下Struts1的相关知识,其实Struts现在是出名的,每个Web开发者都会知道的,也是现在比较流行的框架,下面就来看一下我们为什么要用Struts框架呢? 摘要 1.建立在mvc这种好的 ...
- Struts1之logic标签
logic是Struts1中的逻辑标签 <%@ taglib prefix="logic" uri="http://struts.apache.org/tags-l ...
- apache环境.htaccess设置301跳转及常用.htaccess技巧整理
apache环境.htaccess设置301跳转及常用.htaccess技巧整理 无论是Nginx,还是Apache都各自有优势,对于我们普通用户而言基本上也没有多大的区别.在虚拟主机环境中,基本上都 ...
- 传智博客(JavaWeb方面的所有知识)听课记录(经典)
一. JavaWeb基础 第一天: 1.Eclipse详解: (1).Bad versionnumber in .class file:编译器版本和运行(JRE)版本不符合.高的JRE版本 ...
- Struts2框架基础
Struts2框架基础 1.Java的框架 1.1.框架简介 在大型项目开发过程中,经常会使用到一些框架,这样做好的好处是能够提高工作效率,在java中最常用的的框架就是SSH,这其实是三个框架的简称 ...
随机推荐
- hbase centos7 安装体验
1. 准备需要jdk1.8,hbase安装文件.大家可以官网下载. 解压文件,复制到指定目录 tar -zxvf jdk-8u201-linux-x64.tar.gz tar -zxvf hbas ...
- CET-6 分频周计划生词筛选(Week 2)
点我阅读 Week 2 2016.09.04/05 p58 ongoing / forward p59 prosperity p60 rear p61 rival + segregation + se ...
- subprocess 模块 与 re 模块
sub :子 process:进程 用法: import subprocess while True: cmd_str = inport('请输入终端命令:') obj = subprocrss.Po ...
- vue证明题二,让vue跑起来
使用vue有很多连带产品,大多数入门的并非看不懂官方文档,也并非不会语法,而是卡在这些连带产品上 笔者刚刚入手这台电脑,什么都没装,就以此开始,从头构建一个vue项目吧,哪怕没有任何基础,跟着来应该是 ...
- HTTP Request 422 Unprocessable Entity
最近接了一个接口,在调用接口时,返回这个错误代码. 百度到的解释是:请求格式正确,但是由于含有语义错误,无法响应. 开始一直在纠结,语义错误到底是什么?对照了无数次参数名,传参方式,无解. 后来用Fi ...
- PROXY——代理模式
代理,说白了就是中介.假设有俩对象A和B,A想访问B,但是根据迪米特法则,我们不能喝陌生人说话,简而言之就是A要减少知道B的相关情况,要降低A与B的耦合度.这时我们使用中介C,而C拥有B的相关情况,A ...
- unittest接口自动化测试报告
unittest接口自动化测试报告 展示: 代码: __author__ = "Wai Yip Tung, Findyou" __version__ = "0.8.2.1 ...
- 深度探索C++对象模型第四章:函数语义学
C++有三种类型的成员函数:static/nonstatic/virtual 一.成员的各种调用方式 C with class 只支持非静态成员函数(Nonstatic member function ...
- 【串线篇】依赖注入DI与控制反转IOC
DI&IOC 在spring框架中DI与IOC说的其实是一回事 一句话:本来我接受各种参数来构造一个对象,现在只接受一个参数——已经实例化的对象. 也就是说我对对象的『依赖』是注入进来的,而和 ...
- python3.x 类似cpp引用指针传参修改
#同名局部变量调用外部全局变量: num=100def fun(): global num#告诉编译器是全局的num num+=100 print(num)print(fun)print(fun()) ...