Struts2框架之struts.xml详解
[TOC]
一个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>
<!-- 声明常量 -->
<constant name="struts.i18n.encoding" value="UTF-8"></constant> <!-- 可以帮助我们解决post请求乱码问题 -->
<!-- <constant name="struts.action.extension" value="action"></constant> --><!-- 指定访问strtsu2框架路径的扩展名 -->
<constant name="struts.devMode" value="true"></constant>
<!-- 配置这项后,它会提供更加详细报错信息,以及在struts.xml文件修改后不在需要重启服务器 -->
<constant name="struts.enable.DynamicMethodInvocation" value="true"></constant><!--
开启动态方法调用 -->
<package name="default" namespace="/" extends="struts-default">
<global-results>
<result name="" type=""></result>
</global-results>
<action name="struts2" class="cn.thc.web.action.Struts2Action"></action>
<action name="login" class="cn.thc.web.action.LoginAction"
method="login">
<result name="success" type="redirect">/success.jsp</result>
<result name="failer">/failer.jsp</result>
</action>
<action name="login1" class="cn.thc.web.action.LoginAction1"
method="login">
<result name="success" type="redirect">/success.jsp</result>
<result name="failer">/failer.jsp</result>
</action>
<action name="login2" class="cn.thc.web.action.LoginAction2"
method="login">
<result name="success" type="redirect">/success.jsp</result>
<result name="failer">/failer.jsp</result>
</action>
<action name="test">
<result>/success.jsp</result>
</action>
<!-- <action name="bookadd" class="cn.thc.web.action.BookAction" method="addBook"></action>
<action name="bookupdate" class="cn.thc.web.action.BookAction" method="updateBook"></action>
<action name="bookdel" class="cn.thc.web.action.BookAction" method="delBook"></action>
<action name="bookfind" class="cn.thc.web.action.BookAction" method="findBook"></action> -->
<!-- 以上操作可以简化,使用*通配置来操作 -->
<!-- <action name="*_*" class="cn.thc.web.action.{1}Action" method="{2}"></action> -->
</package>
</struts>
package标签的配置
- name属性,作用是定义一个包的名称,它必须唯一.即在struts.xml中可以配置多个package,但这些package的name不可以重复. package是用来管理action的.
- namespace属性, 作用是与action标签的name属性联合使用来确定一个action的访问路径.
例如在jsp中的form表单的action如下
action="${pageContext.request.contextPath}/login.action"
那么在package标签的namespace配置了"/"
在action标签中的name属性配置了"login". 那么该form表单即可对这个action进行访问了. -
extends属性, 作用是指定继承哪个包. 可以把struts的package类比为java中的一个类,那么java中的类是可以继承父类的属性和方法的. 类似的,继承了某个包,那么就代表继承的包的配置也就生效了.
一般是继承struts-default.
struts-default包是在struts-default.xml中声明的.
struts-default.xml是在struts2-core的jar包中的
- abstract属性, 可以在上面的截图中看到struts-default包有abstract属性, 并且为true, 代表这个包是抽象的.
类似于java中的抽象类, 是不能创建对象的,必须有其子类继承了抽象类才能调用抽象类中的成员变量和方法.
那么在包中写abstract为true,代表当前的包是抽象的, 主要是用于被其他包继承的.
action标签的配置
- name属性, 作用是与package的namespace联合使用来确定一个action的访问路径
- class属性, 作用是指示当前访问的action类.
- method属性, 用于指示当前的action类中的哪个方法执行.
result标签的配置
主要作用是指示结果视图的.
- name属性, 作用是与action类的method方法返回值进行匹配, 来确定跳转的路径的. name中的值为方法的返回值, result的标签体为跳转的jsp
- type属性, 作用是指定该方法的跳转方式, 默认的是请求转发.
如果值为type="redirect"
代表重定向到某个jsp.
如果值为redirectAction
代表重定向到某个action中.
关于action标签配置的默认值
先来做一个实验, 在struts.xml中编写如下的action访问映射
<action name="test">
<result>/success.jsp</result>
</action>
- 可以看到在上面的action标签的配置中,是没有写class和method属性的.
<result>标签也没有写name属性的值. - 这个时候,启动项目,在浏览器上访问
http://localhost:8080/项目名/test
发现是可以跳转到success.jsp页面的. - 原因首先是该包继承了
extends="struts-default"
struts-default包是在struts-default.xml文件中的,有定义一个默认的class
<default-class-ref class="com.opensymphony.xwork2.ActionSupport" />
会执行ActionSupport类的如下的execute方法
public String execute() throws Exception {
return SUCCESS;
}
/**
* The action execution was successful. Show result
* view to the end user.
*/
public static final String SUCCESS = "success";
从该方法中可以看到,不执行任何的业务逻辑代码,返回success常量.
也就说明了,class的默认值是com.opensymphony.xwork2.ActionSupport
method的默认值是execute, 即默认访问的是excuse方法.
默认的跳转方式是dispatcher请求转发.
- 如果在action标签中,有配置了自己写的类,但是这个类没有写execute方法,在配置action标签的时候,也没有写method属性,那么会报如下的异常
NoSuchMethodException
表示你当前的的类中没有写execute方法. 写上方法,就不会报异常了.