拦截器
概述
- Struts 2大多数核心功能是通过拦截器实现的,每个拦截器完成某项功能。拦截器方法在Action执行之前或之后执行
拦截器栈
- 从结构上看,拦截器栈相当于多个拦截器的组合
- 在功能上看,拦截器栈也是拦截器
拦截器工作原理
- 拦截器的执行过程是一个递归的过程
自定义拦截器
方法一
实现Interceptor接口
- void init():初始化拦截器所需资源
- void destory():释放在init()中分配的资源
- String intercept(ActionInvocation ai) throwa Exception
- 实现拦截器功能
- 利用ActionInvocation参数获取Action状态
- 返回result字符串作为逻辑视图
方法二
继承AbstractInterceptor类
- 提供了init()和destory()方法的空实现
- 只需要是西安intercept方法即可
拦截器示例
计算Action的执行时间
实现步骤
- 创建拦截器
- 在配置文件中定义拦截器并引用它
index.jsp
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>计算Action花费的时间</title>
</head>
<body>
<a href="timer">访问Action并计算Action花费的时间</a>
</body>
</html>
struts2.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.5//EN"
"http://struts.apache.org/dtds/struts-2.5.dtd">
<struts>
<!-- -启动动态方法调用 -->
<constant name="struts.enable.DynamicMethodInvocation" value="true" />
<!-- 指定struts2处于开发阶段,可以进行调试 -->
<constant name="struts.devMode" value="true" />
<package name="default" namespace="/" extends="struts-default">
<!-- 注册拦截器 -->
<interceptors>
<interceptor name="mytimer" class="com.xlr.interceptor.TimerInterceptor"></interceptor>
</interceptors>
<action name="timer" class="com.xlr.action.TimerAction">
<result>/success.jsp</result>
<!-- 引用拦截器 -->
<interceptor-ref name="mytimer"></interceptor-ref>
</action>
</package>
</struts>
TimerInterceptor.java
/**
*
*/
package com.xlr.interceptor;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.AbstractInterceptor;
/*
*@Author:小龙人
*@File Name:TimerInterceptor.java
*@Created Time:下午3:19:24
*@Introduce Function:计算Axtion花费的时间
*/
public class TimerInterceptor extends AbstractInterceptor {
/**
*
*/
private static final long serialVersionUID = 1L;
/* (non-Javadoc)
* @see com.opensymphony.xwork2.interceptor.AbstractInterceptor#intercept(com.opensymphony.xwork2.ActionInvocation)
*/
/**
* 执行Action时自动调用此方法
*/
@Override
public String intercept(ActionInvocation invocation) throws Exception {
//记下开始时间
long start = System.currentTimeMillis();
//执行下一个拦截器,如果是最后一个,则执行目标Action
String result = invocation.invoke();
//结束时间
long end = System.currentTimeMillis();
System.out.println("执行Action花费时间:"+(end - start)+"ms");
return result;
}
}
TimerAction.java
/**
*
*/
package com.xlr.action;
import com.opensymphony.xwork2.ActionSupport;
/*
*@Author:小龙人
*@File Name:TimerAction.java
*@Created Time:下午3:08:43
*@Introduce Function:TODO
*/
public class TimerAction extends ActionSupport{
@Override
public String execute() throws Exception {
for(int i =0;i < 100; i++){
System.out.println("I am xlr!");
}
return SUCCESS;
}
}