Struts2框架之Action配置
- Action配置
- 1、访问Action的三种方式
- 1.1、method属性访问
- 1.2、Action动态方法调用
- 1.3、通配符调用
- 2、配置默认的Action
Action配置
Action控制器在Struts2框架中至关重要,主要作用如下:
- 封装工作单元
- 数据转移的场所
- 返回结果字符串
1、访问Action的三种方式
访问Action控制器有三种方式,可通过method属性访问,可通过Action动态方法调用,也可通过通配符调用。
1.1、method属性访问
通过method属性实现在Action中不同方法的调用,该方式可以避免动态方法调用的安全隐患,但缺点是会导致大量的Action配置。demo如下:
(1)Action控制器
public class Login2Action extends ActionSupport {
public String loginRequest() {
System.out.println("用户登录");
return SUCCESS;
}
public String registerRequest() {
System.out.println("用户注册");
return SUCCESS;
}
public String updateRequest() {
System.out.println("用户更新");
return SUCCESS;
}
public String deleteRequest() {
System.out.println("用户删除");
return SUCCESS;
}
}
(2)struts.xml配置
<package name="user1" extends="default" namespace="/user">
<!-- 登录请求 -->
<action name="login" class="com.ycz.struts01.action.Login2Action" method="loginRequest">
<result>/success.jsp</result>
</action>
<!-- 注册请求 -->
<action name="register" class="com.ycz.struts01.action.Login2Action" method="registerRequest">
<result>/success.jsp</result>
</action>
<!-- 登录请求 -->
<action name="update" class="com.ycz.struts01.action.Login2Action" method="updateRequest">
<result>/success.jsp</result>
</action>
<!-- 登录请求 -->
<action name="delete" class="com.ycz.struts01.action.Login2Action" method="deleteRequest">
<result>/success.jsp</result>
</action>
</package>
注意的是,这个package的配置是继承上面name为default的package的:
并且这个package的命名空间为/user,请求需要加/user这个前缀。
(3)页面
访问页面login2.jsp如下:
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<a href="user/login.action">登录请求</a><br/>
<a href="user/register.action">注册请求</a><br/>
<a href="user/update.action">更新请求</a><br/>
<a href="user/delete.action">删除请求</a>
</body>
</html>
跳转页面success.jsp如下:
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ taglib prefix="s" uri="/struts-tags" %>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>主页面</title>
</head>
<body>
<h1>请求成功</h1>
</body>
</html>
(4)测试
启动项目,访问http://localhost:8081/struts01/login2.jsp:
依次点击这4个链接,控制台与页面对应:
能够正确的进入到Action中对应的方法,没问题。
1.2、Action动态方法调用
使用动态方法调用时,需要先在struts.xml配置中开启:
然后在公用package标签内设置白名单:
最后配置一个Action即可,直接在第一种方式的配置上进行修改:
这种方式省略了大量的action标签配置,很简便。
修改页面的访问链接:
url的形式为命名空间/对应action配置的name值!方法名.action
,测试略。
1.3、通配符调用
通配符调用实际上是另一种形式的动态方法调用。直接在上面的基础上进行修改:
action的name值匹配以User结尾的请求,method属性匹配第一个参数。
修改页面的访问链接:
url的形式为命名空间/对应action的方法名 + 通配符.action
,测试略。
2、配置默认的Action
当Struts2没有Action匹配请求时,默认Action将被执行。需要在公共的package标签内进行配置:
先配置action,然后使用default-action-ref进行引用,需要注意的是,在struts.xml中,default-action-ref标签必须放在action标签的前面。
对应的404.jsp页面如下:
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>404页面</title>
</head>
<body>
<h2 style="color:red;font-weight: bold;">抱歉,找不到页面!</h2>
</body>
</html>
访问一个不存在的action测试:
匹配到了默认的action配置,页面跳转正确。