Struts2入门详解(二)

Action的编写方式:

	Action是一个POJO的类(POJO:Plain Ordinary Java Object 简单java对象)
	理论上,一个POJO类中,满足类似下面的格式,都可以看作是Struts2的Action实现
		public class ActionDemo{
			public String execute(){
				return null;
			}
		}

1.Action类实现一个Action的接口

		为了让开发Action更规范,提供Action接口,可以实现这个Action接口。

		public class ActionDemo implements Action{
			public String execute() throws Exception{
				return null;
			}
		}
		Action接口中规定了Action处理类应该包含一个execute()方法,该方法返回一个字符串。除此之外,
		接口中还定义了5个字符串常量,作用是统一execute()方法的返回值。

		五个常量如下:
		SUCCESS	:	success,代表成功
		NONE		none,代表不跳转
		ERROR		error,代表跳转错误页面
		INPUT	:	input,数据校验时跳转的路径
		LOGIN	:	login,用来跳转登录页面


注意:开发中很少直接实现Action接口

2.Action类继承ActionSupport类(推荐使用

		public class ActionDemo extends ActionSupport{
			public String execute() throws Exception{
				return NONE;
			}
		}

		ActionSupport类本身实现了Action接口,是Struts2默认的Action接口的实现类。继承ActionSupport就相当于
		实现了Action接口。
		ActionSupport还实现了其他接口,例如:TextProvider、Serializable等接口,提供更多的功能。

		ActionSupport类提供了许多默认的方法:
			获取国际化信息的方法
			数据校验的方法
			默认处理用户请求的方法
			。。。


Action的访问:

1.一个请求对应一个Action

		页面:
		<h1>一个请求对应一个Action</h1>
		<a href="${pageContext.request.contextPath}/actionDemo.action">请求Action</a>
		
		Action:
		public class ActionDemo extends ActionSupport{
			public String execute() throws Exception{
				return SUCCESS;
			}
		}
		
		配置Action:
		<action name="actionDemo" class="cn.scx.action.ActionDemo">
			<result name="success">/jsp/success.jsp</result>
		</action>
这种方法需要写很多的Action,不推荐。

2.一个请求对应一个Action中的一个方法

		页面:
		<h1>一个请求对应一个Action中的一个方法</h1>
		<a href="${pageContext.request.contextPath}/actionDemo_save.action">请求Action,调用对应的方法</a>
		<a href="${pageContext.request.contextPath}/actionDemo_delete.action">请求Action,调用对应的方法</a>
		<a href="${pageContext.request.contextPath}/actionDemo_update.action">请求Action,调用对应的方法</a>
		
		Action:
		public class ActionDemo extends ActionSupport{
			public String save() throws Exception{
				return NONE;
			}
			public String delete() throws Exception{
				return NONE;
			}
			public String update() throws Exception{
				return NONE;
			}
		}
		
		配置Action:
		<action name="actionDemo_save" class="cn.scx.action.ActionDemo" method="save">
		</action>
		<action name="actionDemo_delete" class="cn.scx.action.ActionDemo" method=delete">
		</action>
		<action name="actionDemo_update" class="cn.scx.action.ActionDemo" method="update">
		</action>


这样的方式很麻烦,同一个Action被配置了很多次。


通配符方式解决:
		页面:
		<h1>一个请求对应一个Action中的一个方法</h1>
		<a href="${pageContext.request.contextPath}/actionDemo_save.action">请求Action,调用对应的方法</a>
		<a href="${pageContext.request.contextPath}/actionDemo_delete.action">请求Action,调用对应的方法</a>
		<a href="${pageContext.request.contextPath}/actionDemo_update.action">请求Action,调用对应的方法</a>
		
		Action:
		public class ActionDemo extends ActionSupport{
			public String save() throws Exception{
				return NONE;
			}
			public String delete() throws Exception{
				return NONE;
			}
			public String update() throws Exception{
				return NONE;
			}
		}
		
		配置Action:
		<action name="actionDemo_*" class="cn.scx.action.ActionDemo" method="{1}"></action>

		name属性中:* 代表任意字符,method属性中{1}代表name属性中*代表的字符。


3.动态方法访问

		动态访问在Struts2中默认是关闭状态,需要使用时,开启一个常量。
		<constant name="struts.enable.DynamicMethodInvocation" value="true"/>

		页面:
		<h1>一个请求对应一个Action中的一个方法</h1>
		<a href="${pageContext.request.contextPath}/actionDemo!save.action">请求Action,调用对应的方法</a>
		<a href="${pageContext.request.contextPath}/actionDemo!delete.action">请求Action,调用对应的方法</a>
		<a href="${pageContext.request.contextPath}/actionDemo!update.action">请求Action,调用对应的方法</a>
		
		Action:
		public class ActionDemo extends ActionSupport{
			public String save() throws Exception{
				return NONE;
			}
			public String delete() throws Exception{
				return NONE;
			}
			public String update() throws Exception{
				return NONE;
			}
		}
		
		配置Action:
		<action name="actionDemo" class="cn.scx.action.ActionDemo"></action>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值