Struts2使用11 -- 拦截器1 -- 概述

来源:互联网 发布:sql on storm 编辑:程序博客网 时间:2024/05/01 02:04

 

Struts2中提供的很多特性都是通过拦截器实现的,例如异常处理,文件上传,生命周期回调与验证。拦截器从概念上来讲和Servlet过滤器或者JDK Proxy类是一样的。它提供了一种对Action进行预处理和事后处理的功能。和Servlet 过滤器一样,拦截器可以被分层和排序。它还可以访问所执行的Action和所有的环境变量与执行属性。

Struts2内建了大量的拦截器,这些拦截器以name-class对的形式配置在struts-default. xml文件中,其中name是拦截器的名字,就是以后使用该拦截器的唯一标识;class则指定了该拦截器的实现类,如果我们定义的package继承了Struts2的默认struts-default包,则可以自由使用下面定义的拦截器,否则必须自己定义这些拦截器。

让我们从依赖注入来开始对拦截器的介绍。正如我们已经看到的一样,依赖注入可以多种不同的实现方式。下面就是对应于不同实现方式的拦截器:

l         Spring 框架——ActionAutowiringInterceptor拦截器

l         请求字符串和表单值—— ParametersInterceptor拦截器

l         基于Servlet的对象——ServletConfigInterceptor拦截器

前两种拦截器可以独立工作,不需要Action的帮助,但是最后一种不同,它是在以下几种接口的辅助下工作的:

l         SessionAware ——通过Map来提供对所有session属性的访问

l         ServletRequestAware——提供对HttpServletRequest对象的访问

l         RequestAware ——通过Map来提供对所有request属性的访问

l         ApplicationAware ——通过Map来提供对所有applicatin属性的访问

l         ServletResponseAware ——提供对HttpServletResponse对象的访问

l         ParameterAware ——通过Map来提供对所有request string和表单数据的访问

l         PrincipalAware ——提供对PrincipleProxy对象的访问;该对象实现了HttpServletRequest对象的有关principle role的方法,但是它提供了一个Proxy,因此所有的实现都是独立于Action的。

l         ServletContextAware ——提供对ServletContext对象的访问

如果要把数据注入到Action中去,那么对应的数据就需要实现必需的接口。

原创粉丝点击