一、简介
Struts
2是一个MVC框架,以WebWork设计思想为核心,吸收了Struts 1的部分优点
二、详解
首先让我们看一下一个简单的struts.xml文件的结构
<?xml version="1.0"
encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
"-//Apache
Software Foundation//DTD Struts Configuration 2.3//EN"
"http://struts.apache.org/dtds/struts-2.3.dtd">
<struts>
<package name="struts2"
extends="struts-default">
<action name="login"
class="com.action.LoginAction">
<result
name="success">/welcom.jsp</result>
<result
name="fail">/index.jsp</result>
</action>
</package>
</struts>
A、struts.xml中各个节点以及属性的含义
package节点类似JAVA中的包,STRUTS2引用包的概念;
name属性就是包名,可以根据业务或功能分类定义不同的包,避免命名冲突;
namespace类似于命名空间,决定内部所有的ACTION访问URL的父级地址,
如(namespace=“/demo/page”,以下访问的路径就需要加上“http://localhost:8080/项目名/demo/page/”);
extends属性必须写上,而且值必须是“struts-default”,这样才能够实现struts2的功能。
ction节点可以有多个,表示同个包中多个动作指向URL;
action节点中的name属性是指定访问时的URL文件名,如上所示的的完整URL
是:http://localhost:8080/项目名/demo/page/hello;
class属性是指定当前URL所指向的action的完整类名,如果不指定值,则默认是XWORK包中的ActionSupport类;
method属性是指向action类中的执行方法,该方法可以自定义,但返回值必须是字符串,如果不指定值,默认是:excute方法。
result节点中的name属性值是指定action类中的method所指定的方法返回的字符串值,节点中的文本是指向当接收到name的值时转发的URL路径。
B、Action名称的搜索顺序
1.获得请求路径的URI,例如url是:http://localhost:8080/struts2/path1/path2/path3/test.action
2.首先寻找namespace为/path1/path2/path3的package,如果存在这个package,则在这个package中寻找名字为test的action,如果不存在这个package则转步骤3;
3.寻找namespace为/path1/path2的package,如果存在这个package,则在这个package中寻找名字为test的action,如果不存在这个package,则转步骤4;
4.寻找namespace为/path1的package,如果存在这个package,则在这个package中寻找名字为test的action,
如果仍然不存在这个package,就去默认的namaspace的package下面去找名字为test的action(默认的命名空间为空字符串""
),如果还是找不到,页面提示找不到action。
C、Action配置中的各项默认值
1>如果没有为action指定class,默认是ActionSupport。
2>如果没有为action指定method,默认执行action中的execute()
方法。
3>如果没有指定result的name属性,默认值为success。
D、配置Result
一个result代表了一个可能的输出。当Action类的方法执行完成时,它返回一个字符串类型的结果码,框架根据这个结果码选择对应的result,向用户输出。
在com.opensymphony.xwork2.Action接口中定义了一组标准的结果代码,可供开发人员使用,如下所示:
public interface Action
{
public
static final String SUCCESS = “success”;
public
static final String NONE = “none”;
public
static final String ERROR = “error”;
public
static final String INPUT = “input”;
public
static final String LOGIN = “login”;
}
在Struts2中,预定义了一些Result的字符串常量,如下:
SUCCESS:表示Action执行成功,显示结果视图给用户,值为字符串"success"。
NONE:表示Action执行成功,不需要显示视图给用户,值为字符串"none"。
ERROR:表示Action执行失败,显示错误页面给用户,值为字符串"error"。
INPUT:表示执行Action需要更多的输入信息,回到input对应的页面,值为字符串"input"。
LOGIN:表示因用户没有登陆而没有正确执行,将返回该登陆视图,值为字符串"login"。
当然,你可以不使用这些字符串常量,而是使用自己定义的字符串,这样做是没有问题的,只要你在Action里面返回的字符串,跟在struts.xml里面配置的result的name属性值一样就可以了。
##################################################
Struts 2
"input"视图有以下各种用法:
1、当所配置的action返回"input"字符串时,strust 2 会将其定向到input视图。
2、当从客户端发送信息到服务器到会话进入所对应的action类方法前有错误(如action的hasError方法返回true)和异常发生,例如:struts
2容器给对应action的各变量赋值时发生发生类型匹配、数据验证没有通过、或者有拦截器抛出异常等。
3、如果在定向到input视图前有错误(如action的hasError方法返回true)和异常发生,且返回的input视图的type
为"chain"(即返回到另一个action)时,这个action的方法必须为input,否则这个方法不会执行,而是会直接定位到物理视图。
E、配置 result映射
在result映射的配置中,在指定实际资源的位置时,可以使用绝对路径,也可以使用相对路径。
绝对路径以斜杠(/)开头,相对于当前的Web应用程序的上下文路径;
相对路径不以斜杠(/)开头,相对于当前执行的action的路径。
例如:
<package name="default"
extends="struts-default" namespace="/admin">
<action name="login"
class="com.ibm.LoginAction">
<result>success.jsp</result>
<result
name="error">/error.jsp</result>
</action>
</package>
如果当前Web应用程序的上下文路径是/Shop,那么请求/Shop/admin/login.action,执行成功后,转向的页面路径为:/Shop/admin/success.jsp;执行失败后,转向的页面路径为/Shop/error.jsp.
F、result结果类型
在框架调用Action对请求进行处理之后,就要向用户呈现一个结果视图。Struts2支持多种类型的视图,这些视图是由不同的结果类型来管理的。一个
结果类型就是实现了com.opensymphony.xwork2.Result接口的类,在struts2中,预定义了多种结果类型,如表:
结果类型在包中使用result-type元素来定义,上面的结果类型都是在框架的默认配置文件struts-default.xml中定义的。
result节点中有type属性,用于指定指向URL路径的方式,主要值有:dispatcher(默认值),redirect,redirectAction,plainText等。
其中当使用redirectAction值时,是直接写重定向到其他action,如果是指向当前包下面的其他ACTION,则中间节点直接写ACTION名称即可,如果是指向其他包中的ACTION,则需要添加PARAM节点,如:
<param
name="actionName">其他ACTION的名称</param>
<param
name="namespace">ACTION所在的命名空间</param>
其中当使用plainText值时,一般是应用于将某个页面的源代码(含有服务器段代码)直接输出到页面,如:
<result type="plainText">
<param
name="location">/index.jsp</param>
<param
name="charset">utf-8</param>
</result>