在struts.xml中配置
1.配置拦截器
<interceptors>
<interceptor name="" class="">
<param name="">value</param>
.......
</interceptor>
<interceptor-stack name="">
<interceptor-ref name=""/>
<interceptor-ref name="">
<param name="">value</param>
</interceptor-ref>
</interceptor-stack>
</interceptors>
2.使用拦截器
<action>
<result/>
<interceptor-ref name=""/>
<interceptor-ref name="defaultStack"/>
</action>
3.配置包的默认拦截器
<struts>
<package name="" extends="struts-default">
<interceptors>
.......
....
</interceptors>
<default-interceptor-ref name="">
<param name="">value</param>
</default-interceptor-ref>
<action/>
</package>
</struts>
如果没有指定stack,默认使用defaultStack。
配置了拦截器(栈),就不适用默认了。如要使用,指出。如上。
4.自定义拦截器
实现Interceptor接口
或者继承AbstractInterceptor类
4.方法过滤拦截器。
对action中的特定方法实行过滤
继承MethodFilterInterceptor,重写了AbstractInterceptor的Interceptor方法(应该是现实了方法过滤),提供了doIntercept方法来实现用户的行为。
配置:
<action>
....
....
<interceptor-ref name="">
<param name="excludeMethods">value1,value2,value3</param>
<param name="includeMethods">value1,value2,value3</param>
</interceptor-ref>
</action>
一个方法同时被exclude和include。则以include为准。
Struts2 默认提供的方法过滤拦截器有:
DefaultWordflowInterceptor
TokenInterceptor (防止表单重复提交)
TokenSessionInterceptor(同上)
ValidationInterceptor
5.拦截结果监听器
原来的interceptor中的代码:
code1....
.......
ai.invoke()
code2.....
.....
现在我们要将code2剥离出来,实现解耦。(有没有必要?好像太复杂了) 可以通过实现PreResultListerner接口来实现。重写beforeResult(ActionInvocation ai, String result)方法。其中result是action返回的值。
注意:在beforeResult()方法中,不要再调用ai.invoke方法,这样会造成死循环。
5.覆盖拦截器中的参数。(不太会用到)
在action中使用拦截器栈。要覆盖其中某个拦截器的默认配置参数。这个参数也可能与拦截器栈中的其他参数重名。配置方法:
<interceptor-stack name="Stack">
<interceptor-ref name="first">
<interceptor-ref name="second">
<param name="same">value</param>
</interceptor-ref>
<interceptor-ref name="second">
<param name="same">value</param>
</interceptor-ref>
</interceptor-stack>
<action>
<result/>
<interceptor-ref name="Stack">
<param name="first.same">value</param>
</interceptor-ref>
</action>
如上,通过使用“拦截器名.参数名”的方法来覆盖默认参数。
1.配置拦截器
<interceptors>
<interceptor name="" class="">
<param name="">value</param>
.......
</interceptor>
<interceptor-stack name="">
<interceptor-ref name=""/>
<interceptor-ref name="">
<param name="">value</param>
</interceptor-ref>
</interceptor-stack>
</interceptors>
2.使用拦截器
<action>
<result/>
<interceptor-ref name=""/>
<interceptor-ref name="defaultStack"/>
</action>
3.配置包的默认拦截器
<struts>
<package name="" extends="struts-default">
<interceptors>
.......
....
</interceptors>
<default-interceptor-ref name="">
<param name="">value</param>
</default-interceptor-ref>
<action/>
</package>
</struts>
如果没有指定stack,默认使用defaultStack。
配置了拦截器(栈),就不适用默认了。如要使用,指出。如上。
4.自定义拦截器
实现Interceptor接口
或者继承AbstractInterceptor类
4.方法过滤拦截器。
对action中的特定方法实行过滤
继承MethodFilterInterceptor,重写了AbstractInterceptor的Interceptor方法(应该是现实了方法过滤),提供了doIntercept方法来实现用户的行为。
配置:
<action>
....
....
<interceptor-ref name="">
<param name="excludeMethods">value1,value2,value3</param>
<param name="includeMethods">value1,value2,value3</param>
</interceptor-ref>
</action>
一个方法同时被exclude和include。则以include为准。
Struts2 默认提供的方法过滤拦截器有:
DefaultWordflowInterceptor
TokenInterceptor (防止表单重复提交)
TokenSessionInterceptor(同上)
ValidationInterceptor
5.拦截结果监听器
原来的interceptor中的代码:
code1....
.......
ai.invoke()
code2.....
.....
现在我们要将code2剥离出来,实现解耦。(有没有必要?好像太复杂了) 可以通过实现PreResultListerner接口来实现。重写beforeResult(ActionInvocation ai, String result)方法。其中result是action返回的值。
注意:在beforeResult()方法中,不要再调用ai.invoke方法,这样会造成死循环。
5.覆盖拦截器中的参数。(不太会用到)
在action中使用拦截器栈。要覆盖其中某个拦截器的默认配置参数。这个参数也可能与拦截器栈中的其他参数重名。配置方法:
<interceptor-stack name="Stack">
<interceptor-ref name="first">
<interceptor-ref name="second">
<param name="same">value</param>
</interceptor-ref>
<interceptor-ref name="second">
<param name="same">value</param>
</interceptor-ref>
</interceptor-stack>
<action>
<result/>
<interceptor-ref name="Stack">
<param name="first.same">value</param>
</interceptor-ref>
</action>
如上,通过使用“拦截器名.参数名”的方法来覆盖默认参数。