Struts2提供面向切面编程(AOP Aspect-Oriented Programing)。在Struts2中拦截器是一种成熟的AOP的实现。
拦截器(Intercaptor)在Action前后执行。
类似于Filter Chain(过滤器链),多个拦截器组成拦截器栈(Inteceptor stack)。
拦截器和Filter的区别
对于Struts2的拦截器特性,和servlet的Filter如出一辙,思想基本相同,但在具体的使用上和Fileter是有区别的。
1.在Filter中是依赖Servlet Api的但是在Struts2中是不与Servelet Api产生耦合的。(这个也是Struts2的好处)。
2.二者的实现细节不同。拦截器是基于java的反射机制的,而过滤器是基于函数回调 。3.拦截器的拦截策略的配置和Fileter的过滤策略的配置形式也是不同的。这决定了拦截器只能对action请求起作用,而过滤器则可以对几乎所有的请求起作用 4.拦截器可以访问action上下文、值栈里的对象,而过滤器不能 5.在action的生命周期中,拦截器可以多次被调用,而过滤器只能在容器初始化时被调用一次
关于拦截器和过滤器的不同参考
http://gkuiyj.iteye.com/blog/458003
http://czjxdm.iteye.com/blog/148172
拦截器的作用
在Struts2中很多特性是通过拦截器实现的,比如数据校验,Action中的表单属性注入等等。拦截器通过把一段代码封装起来进行单独的业务处理。
拦截器的核心优点
拦截器的好处是能允许程序员把相对独立的代码封装起来。
Struts2中利用AOP实现拦截器的细节
关于拦截器在整个Struts2程序运行中的细节以及拦截器实现的细节请参看Struts2源码。作者会续关于Struts2源码分析的文章。
实现拦截器类
所有的拦截器都实现interceptor接口,一般继承AbstractIntercaptor抽象类。
这个抽象类定义了一个抽象方法,这个方法返回一个字符串,传进一个ActionInvocation接口的实例
public String intercept(ActionInvocation invocation) throws Exception {}
比如一下例子,一个登陆验证拦截器。当用户没有登陆时直接跳到登陆页面,用户登陆之后则正常请求。
public String intercept(ActionInvocation invocation) throws Exception { //获取Action上下文 ActionContext actionContext = invocation.getInvocationContext(); Map<String, Object> session = actionContext.getSession(); String account = (String) session.get("account"); if(account==null)return Action.LOGIN;//要是没有帐户信息的话返回"login" return invocation.invoke();//要是有帐户信息的话,继续进行下一个拦截器或者Action }
配置拦截器
strust.xml
<package name="main" > //定义此拦截器 <interceptors> <interceptor name="loginInterceptor" class="com.interceptors"></interceptor> </interceptors> <action name="UserAction" class="com.actions.UserAction"> //引用此拦截器,表明拦截器对此Action有效 <interceptor-ref name="loginInterceptor"><interceptor-ref> </action> </package>
从配置看来,interceptor只能拦截Action不能拦截其他请求,比如.jsp.txt.jsp。而过滤器则能。因为在过滤策略上Fielter采用访问路径的方式配置。