主要内容:
- include包含
- 默认action(default)
- result配置
- 全局结果集
一、include包含
以后在实际开发中我们可能会将一个系统分成多个模块进行开发,于是我们的配置文件也需要分模块。我们使用标签<include>
将多个配置文件组合在一起。
相关代码:(工程Struts2_1300_IncludeModules
)
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.devMode" value="true" />
<constant name="struts.enable.DynamicMethodInvocation" value="true"/>
<include file="login.xml"></include>
</struts>
login.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="login" extends="struts-default" namespace="/login">
<action name="login*" class="com.bjsxt.struts2.user.action.LoginAction{1}">
<result>/user_login_success.jsp</result>
</action>
</package>
</struts>
这个标签使用较为简单,这里不再多说。
二、默认action
我们在给系统配置的对应功能的action之后,用户在访问的时候可能会访问我们没有配置的action,为了让系统更加友好,我们一般配置一个默认action,如果用户访问的action我们没有配置,那么就找默认action。
相关代码:(工程Struts2_1400_DefaultAction
)
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.devMode" value="true" />
<constant name="struts.enable.DynamicMethodInvocation" value="true"/>
<package name="default" namespace="/" extends="struts-default">
<default-action-ref name="index"></default-action-ref>
<action name="index">
<result>/default.jsp</result>
</action>
</package>
</struts>
说明:此时如果我们不写action名或者写错误的action名字都会跳转到默认action。
三、result配置
我们可以对result配置不同类型达到不同的跳转目的。
相关代码:(工程Struts2_1500_ResultType
)
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.devMode" value="true" />
<constant name="struts.enable.DynamicMethodInvocation" value="true"/>
<package name="resultTypes" namespace="/r" extends="struts-default">
<action name="r1">
<result type="dispatcher">/r1.jsp</result>
</action>
<action name="r2">
<result type="redirect">/r2.jsp</result>
</action>
<action name="r3">
<!--不要加斜杠,如果是在某个包中,可以这样xx/r1-->
<result type="chain">r1</result>
</action>
<action name="r4">
<result type="redirectAction">r2</result>
</action>
</package>
</struts>
index.jsp
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>My JSP 'index.jsp' starting page</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
</head>
<body>
Result类型
<ol>
<li><a href="r/r1">dispatcher</a></li>
<li><a href="r/r2">redirect</a></li>
<li><a href="r/r3">chain</a></li>
<li><a href="r/r4">redirectAction</a></li>
<li>freemarker</li>
<li>httpheader</li>
<li>stream</li>
<li>velocity</li>
<li>xslt</li>
<li>plaintext</li>
<li>tiles</li>
</ol>
</body>
</html>
说明:
- 1.这里我们主要对前四种跳转进行说明,后面的在以后的开发中基本不用或用的很少。
- 2.对于默认的跳转是
type="dispatcher"
,这是通过服务器跳转,相当于forward
跳转,当我们访问r1这个action的时候跳转到r1.jsp
。点击超链接访问的时候是访问的action,地址是http://localhost:8080/Struts2_1500_ResultType/r/r1
。 - 3.对于redirect跳转,这是让浏览器再次发起请求,超链接的地址虽然是
http://localhost:8080/Struts2_1500_ResultType/r/r2
,但是我们点击之后地址栏中地址是http://localhost:8080/Struts2_1500_ResultType/r2.jsp
。 - 4.对于chain这种类型,我们可以跳转到另一个action,而不是像上面那种情况访问的是jsp。于是我们点击之后地址栏中显示的是action的地址
http://localhost:8080/Struts2_1500_ResultType/r/r3
,虽然跳转到r1这个action之后又跳转到一个jsp,但是这对地址没有影响。 - 5.对于redirectAction这种类型,和上面的情况有个区别是,虽然都是跳转到另一个Action,但是如果我们跳转到r1则显示另一个action的地址
http://localhost:8080/Struts2_1500_ResultType/r/r1.action
,如果跳转到r2则显示jsp的地址http://localhost:8080/Struts2_1500_ResultType/r2.jsp
。 - 6.最后,我们一般用的较多的也就前面两种。同时我们还可以跳转到其他namespace中的action,可以查看文档:
<action name="login" class="...">
<!-- Chain to another namespace -->
<result type="chain">
<param name="actionName">dashboard</param>
<param name="namespace">/secure</param>
</result>
</action>
这里只是一个简要运用,不再深入。
四、全局结果集
针对某个action
,当其所带参数我们的action
中没有配置相应的跳转时,我们可以使用全局结果集。
相关代码:(工程Struts2_1600_GlobalResult
)
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.devMode" value="true" />
<constant name="struts.enable.DynamicMethodInvocation" value="true"/>
<package name="user" namespace="/user" extends="struts-default">
<global-results>
<result name="mainpage">/main.jsp</result>
</global-results>
<action name="index">
<result>/index.jsp</result>
</action>
<action name="user" class="com.bjsxt.struts2.user.action.UserAction">
<result>/user_success.jsp</result>
<result name="error">/user_error.jsp</result>
</action>
</package>
<package name="admin" namespace="/admin" extends="user">
<action name="admin" class="com.bjsxt.struts2.user.action.AdminAction">
<result>/admin.jsp</result>
</action>
</package>
</struts>
index.jsp
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>My JSP 'index.jsp' starting page</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
</head>
<body>
Result类型
<ol>
<li><a href="user/user?type=1">返回success</a></li>
<li><a href="user/user?type=2">返回error</a></li>
<li><a href="user/user?type=3">返回global result</a></li>
<li><a href="admin/admin">admin,继承user包</a></li>
</ol>
</body>
</html>
UserAction.java
package com.bjsxt.struts2.user.action;
import com.opensymphony.xwork2.ActionSupport;
public class UserAction extends ActionSupport {
private int type;
@Override
public String execute() throws Exception {
if(type == 1){
return "success";
}else if(type == 2){
return "error";
}else{
return "mainpage";
}
}
public int getType() {
return type;
}
public void setType(int type) {
this.type = type;
}
}
AdminAction.java
package com.bjsxt.struts2.user.action;
import com.opensymphony.xwork2.ActionSupport;
public class AdminAction extends ActionSupport {
@Override
public String execute() throws Exception {
return "mainpage";
}
}
说明:
- 1.对于相关的跳转页面这里不再给出,可以自己随便写点什么。
- 2.首先我们访问
index.jsp
,当我们点击第一个和第二个链接时可以分别访问到成功页面和失败页面,因为此时我们的action
中已经分别对type
值为1和2的情况分别进行了处理,但是当点击第三个链接时,我们的action
没有对这种情况进行处理,当然我们是可以对这种情况进行处理的,可是如果这样的值太多的话,每个都分别处理显然很麻烦,于是我们配置了一个全局的结果集,当type
值不为1或者2的时候全部跳转到main.jsp
。这在以后我们配置全局错误页面可以用到。 - 3.对于第四个链接,我们访问的
action
如果不在我们刚才配置的全局结果集所在的包中,那我们也想使用这个全局结果集该怎么办?此时我们可以使用继承,我们让这个包继承上面那个包:extends="user"
。这样我们在不同的包中的action
也可以访问全局结果集了。