struts2中的大部分核心功能都是通过拦截器来实现的,诸如数据校验,类型转换,数据转移。拦截器方法在Action执行之前或者执行之后执行,完成数据数据处理操作。
拦截器的工作流程是一个递归的过程。
在执行Action之前会依次执行一系列的拦截器完成权限的校验或者数据的预处理,
然后执行Action的时候会去执行action中的业务处理方法,然后会返回一个子串,(result),进而根据返回的子串来完成视图的匹配。
而这个结果并没有立即去响应客户端的需求,而是反着去执行之前执行的一系列的拦截器, 当把所有的拦截器都执行完以后才会生成最终对客户端的响应。这和web中讲过的过滤器的原理非常的想象。
自定义拦截器:
方法1:
实现Interceptro接口
void init();
void destroy();
String intercept(ActionInvocation ai) throws Exception
//真正意义上拦截需要调用的方法
1.实现拦截器功能
2.利用ActionInvocation参数获取Action状态
3.返回result字符串作为逻辑视图
(也就是返回的字符串为逻辑视图名)
其中,ai 实例既包括了Action的信息同时也包含了拦截器的信息。
方法2:
继承 AbstractInterceptor类
--提供init()和destroy()方法的空实现
--只需要intercept方法就可以
// 定义一个拦截器的步骤:
step1: 创建好一个继承自AbstractInterceptor的类
:实现intercept()方法
step2:在struts.xml文件中加以配置:
1.注册拦截器
<interceptors>
<interceptor name="timeer" class="定义的拦截器的全类名"></interceptor>
</interceptors>
2.在action里面进行调用,指定要进行拦截的拦截器对象
===========================
另外值得注意的是struts2中内置了许多拦截器,来完成相应的功能
:
params拦截器:
-负责将请求参数设置为Action属性
staticParams拦截器
-将配置文件中的action元素的子元素param参数设置为Action属性
.servletConfig拦截器
-将源于servletAPI的各种对象注入到Action,实现对应的接口。
-fileUpload拦截器
-对文件上传提供支持,将文件和元数据设置到对应的Action属性
-exception拦截器
-捕获异常,并且将异常映射到用户自定义的错误界面
.validation拦截器
--调用验证框架完成对数据的验证
====================================
另外,当用户没有显示的指定struts的拦截器的情况下,struts会调用struts-default.xml文件里面配置好的默认的拦截器----defaultStack,当用户显示的指定后,则默认的拦截器栈就不会起到相应的作用。如果当用户显示指定了拦截器后还想要
继续使用默认的拦截器栈,则需要用户手动引用默认的拦截器栈defaultStack.
另外,要注意引用时候使用的顺序,建议用户先引用系统提供的默认的拦截器,再引用
自定义的拦截器,
<action>
<interceptor-ref name="defaultStack" />
<interceptror-ref name="用户自定义的拦截器的name"/>
<action>
下面是自定义拦截器栈实现对要访问的后台页面权限的拦截,用户必须登录成功后才可以对后台页面访问