当struts2经过输入校验阶段(struts2系列---输入校验)后,接着将调用execute()业务逻辑方法。有时我们需要在执行execute()方法之前先进行比如登陆验证之类的判断。只有登陆过的用户才能进行业务操作。这时就需要用到Struts2的拦截器Interceptor。
以下为struts2拦截器用法的简单小结:
1.
struts.xml配置:
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<package name="default" extends="struts-default">
<interceptors>
<!--定义拦截器-->
<interceptor name="isLogin" class="com.test.action.interceptor.IsLoginInterceptor"></interceptor>
<!--
<!-- 自定义拦截器栈-->
<interceptor-stack name="myStack">
<interceptor name="isLogin"/>
<interceptor name="defaultStack"/>
</interceptor-stack>
-->
</interceptors>
<!--
<default-interceptor-ref name="myStack"></default-interceptor-ref>
-->
<!--定义全局跳转页-->
<global-results>
<result name="login" type="redirect">/login.jsp</result>
</global-results>
<action name="updateMessage" class="com.test.action.UserAction">
<result name="success">/success.jsp</result>
<result name="input">/index.jsp</result>
<result name="failure">/index.jsp</result>
<!--放入上面自定义的拦截器-->
<interceptor-ref name="isLogin"/>
<!--放入struts2默认的拦截器栈-->
<interceptor-ref name="defaultStack"/>
</action>
</package>
</struts>
当执行execute()方法之前被自定义的isLogin拦截器拦截下来进入到IsLoginInterceptor类来进行登陆验证。
IsLoginInterceptor.java:
public class IsLoginInterceptor extends AbstractInterceptor {
@Override
@SuppressWarnings("unchecked")
public String intercept(ActionInvocation invocation) throws Exception
{
//获得Session对象
Map session = invocation.getInvocationContext().getSession();
//判断session中是否有信息
if(session.get("userid") == null)
{
//无信息返回配置文件中<global-results>配置的全局页面
return Action.LOGIN;
}
else
{
//有信息继续执行execute()方法
return invocation.invoke();
}
}
}
注:defaultStack是每个<action/>默认的拦截器栈。然而当用户在<action>中放入了自定义的拦截器的时候,就必须再显式的放入defaultStack。
struts2之所以能在Action类里能做那么多功能,就是依赖于其默认的拦截器栈里定义的各种拦截器。
用户可以配置自己的拦截器栈作为默认的拦截器栈:
只需将配置中的注释解开,<action/>配置里的<interceptor/>也就无需写了。此时自定义的myStack代替了defaultStack拦截器栈
实际开发中,往往配置多个拦截器栈,配置于不同业务模块的<action/>中。
但是注意默认的拦截器栈只能是一个。
2.方法过滤拦截器
默认情况下我们为某个Action定义了拦截器,则这个拦截器会拦截该Action的所有方法。有些情况下,我们无需拦截所有的方法,此时就需要使用方法过滤拦截器。
方法过滤拦截器使用方法与普通的拦截器没什么区别:
方法过滤拦截器类继承MethodFilterInterceptor,
重写的是doIntercept(ActionInvocation invacation)方法
<action/>配置中:
<!--放入上面自定义的拦截器-->
<interceptor-ref name="isLogin">
<!-- 指定login和register方法不需要被拦截-->
<param name="excludeMethods">login,register</param>
<!-- 指定execute方法需要被拦截-->
<param name="includeMethods">execute</param>
</interceptor>