Struts2框架之struts.xml详解

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_33229669/article/details/83444973

Struts2框架之struts.xml详解

一个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标签的配置

  1. name属性,作用是定义一个包的名称,它必须唯一.即在struts.xml中可以配置多个package,但这些package的name不可以重复. package是用来管理action的.
  2. namespace属性, 作用是与action标签的name属性联合使用来确定一个action的访问路径.
    例如在jsp中的form表单的action如下
    action="${pageContext.request.contextPath}/login.action"
    那么在package标签的namespace配置了"/"
    在action标签中的name属性配置了"login". 那么该form表单即可对这个action进行访问了.
  3. extends属性, 作用是指定继承哪个包. 可以把struts的package类比为java中的一个类,那么java中的类是可以继承父类的属性和方法的. 类似的,继承了某个包,那么就代表继承的包的配置也就生效了.
    一般是继承struts-default.
    struts-default包是在struts-default.xml中声明的.
    struts-default.xml是在struts2-core的jar包中的
  4. abstract属性, 可以在上面的截图中看到struts-default包有abstract属性, 并且为true, 代表这个包是抽象的.
    类似于java中的抽象类, 是不能创建对象的,必须有其子类继承了抽象类才能调用抽象类中的成员变量和方法.
    那么在包中写abstract为true,代表当前的包是抽象的, 主要是用于被其他包继承的.

action标签的配置

  1. name属性, 作用是与package的namespace联合使用来确定一个action的访问路径
  2. class属性, 作用是指示当前访问的action类.
  3. method属性, 用于指示当前的action类中的哪个方法执行.

result标签的配置

主要作用是指示结果视图的.

  1. name属性, 作用是与action类的method方法返回值进行匹配, 来确定跳转的路径的. name中的值为方法的返回值, result的标签体为跳转的jsp
  2. type属性, 作用是指定该方法的跳转方式, 默认的是请求转发.
    如果值为type="redirect" 代表重定向到某个jsp.
    如果值为redirectAction代表重定向到某个action中.
    关于请求转发与重定向的区别,可以看下面这篇博文
    https://blog.csdn.net/qq_33229669/article/details/83446189

关于action标签配置的默认值

先来做一个实验, 在struts.xml中编写如下的action访问映射

<action name="test">
     <result>/success.jsp</result>
</action>
  • 可以看到在上面的action标签的配置中,是没有写class和method属性的.
    标签也没有写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方法. 写上方法,就不会报异常了.

猜你喜欢

转载自blog.csdn.net/qq_33229669/article/details/83444973