核心配置文件:
<?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:将Action配置封装.就是可以在Package中配置很多action.
name属性: 给包起个名字,起到标识作用.随便起.不能其他包名重复.
namespace属性:给action的访问路径中定义一个命名空间
extends属性(必填): 继承一个 指定包(这里使用的是默认)
abstract属性(补充):包是否为抽象的; 标识性属性.标识该包不能独立运行.专门被继承
-->
<package name="hello" namespace="/hello" extends="struts-default" >
<!-- action元素:配置action类
name属性: 决定了Action访问资源名,注意不是标识作用
class属性: action类的完整类名
method属性: 指定调用Action类中的哪个方法来处理请求
-->
<action name="HelloAction" class="hello.HelloAction" method="hello" >
<!-- result元素:结果配置
name属性: 标识结果处理的名称.与action方法的返回值对应.
type属性: 指定调用哪一个result类来处理结果,默认使用转发dispatcher.
标签体:填写页面的相对路径
-->
<result name="success" type="dispatcher" >/hello.jsp</result>
</action>
</package>
</struts>
引入其他配置文件:
<include file="dynamic/struts.xml"></include>
src下的相对路径
常量配置:
在struts2核心包下有默认的properties配置文件,当我们需要修改的时候,
第一种方式示例:
自己新建一个配置文件即可
struts.properties:
struts.i18n.encoding=UTF-8
第二种方式示例:
在核心配置文件中写:
<constant name="struts.i18n.encoding" value="UTF-8"></constant>
第三种方式示例:
在web.xml种:
<context-param>
<param-name>struts.i18n.encoding</param-name>
<param-value>UTF-8</param-value>
</context-param>
实际开发中,只使用第二种,其他两种了解即可
其他常量配置(在核心配置文件中):
<!-- i18n:国际化. 解决post提交乱码(不解决get乱码,自行解决) -->
<constant name="struts.i18n.encoding" value="UTF-8"></constant>
<!-- 指定访问action时的后缀名,必须访问Action.do
http://localhost:8080/struts2/hello/HelloAction.do
-->
<constant name="struts.action.extension" value="do"></constant>
<!-- 指定struts2是否以开发模式运行
1.热加载主配置.(不需要重启即可生效)
2.提供更多错误信息输出,方便开发时的调试
-->
<constant name="struts.devMode" value="true"></constant>
还有几个常量配置在Spring中使用,这里暂不介绍
动态方法调用:
这里一个Action中有多个方法:
package dynamic;
//动态方法调用
public class Demo1Action {
public String add() {
System.out.println("添加用户!");
return "success";
}
public String delete() {
System.out.println("删除用户!");
return "success";
}
public String update() {
System.out.println("修改用户!");
return "success";
}
public String find() {
System.out.println("查找用户!");
return "success";
}
}
当前包下新建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>
<!--动态方法调用方式1(不建议)
配置动态方法调用是否开启常量
默认是关闭的(false),需要开启
配置完成后访问....../dynamic/Demo1Action!add即可(!格式固定)
-->
<constant name="struts.enable.DynamicMethodInvocation" value="false"></constant>
<package name="dynamic" namespace="/dynamic" extends="struts-default" >
<!-- 动态方法调用方式2:通配符方式(推荐)
使用{1} 取出第一个星号通配的内容
访问:/dynamic/Demo1Action_add
-->
<!--第一种方式
<action name="Demo1Action" class="dynamic.Demo1Action">
-->
<action name="Demo1Action_*" class="dynamic.Demo1Action" method="{1}" >
<result name="success" >/hello.jsp</result>
</action>
</package>
</struts>
Struts2的默认配置:
package default;
//测试默认配置
public class Demo2Action {
public String execute(){
System.out.println("default");
return "success";
}
}
<?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="default" namespace="/default" extends="struts-default" >
<!-- 找不到包下的action,会使用Demo2Action作为默认action处理请求 -->
<default-action-ref name="Demo2Action"></default-action-ref>
<!-- method的默认属性:execute -->
<!-- result的name默认属性:success -->
<!-- result的type默认属性:dispatcher 转发 -->
<!-- class默认属性:com.opensymphony.xwork2.ActionSupport -->
<action name="Demo2Action">
<result>/hello.jsp</result>
</action>
</package>
</struts>
这里没有配置method,但是默认寻找execute方法
class默认值:找到这个类并调用它的execute方法,这个方法直接返回"success"
来源:oschina
链接:https://my.oschina.net/u/4399904/blog/4237777