Struts2自定义拦截器

来源:互联网 发布:windows系统修复软件 编辑:程序博客网 时间:2024/06/04 01:29

转自:http://blog.csdn.net/yanwushu/article/details/7608311

Struts2提供面向切面编程(AOP Aspect-Oriented Programing)。在Struts2中拦截器是一种成熟的AOP的实现。

拦截器(Intercaptor)Action前后执行。

类似于Filter Chain(过滤器链),多个拦截器组成拦截器栈(Inteceptor stack)


拦截器和Filter的区别

对于Struts2的拦截器特性,和servletFilter如出一辙,思想基本相同,但在具体的使用上和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 {}

比如一下例子,一个登陆验证拦截器。当用户没有登陆时直接跳到登陆页面,用户登陆之后则正常请求。

[java] view plaincopy
  1. public String intercept(ActionInvocation invocation) throws Exception {  
  2.         //获取Action上下文  
  3.         ActionContext actionContext = invocation.getInvocationContext();  
  4.         Map<String, Object> session = actionContext.getSession();  
  5.         String account = (String) session.get("account");  
  6.         if(account==null)return Action.LOGIN;//要是没有帐户信息的话返回"login"  
  7.         return invocation.invoke();//要是有帐户信息的话,继续进行下一个拦截器或者Action  
  8.     }  


配置拦截器


strust.xml

[html] view plaincopy
  1. <package name="main" >  
  2.     //定义此拦截器  
  3.     <interceptors>  
  4.     <interceptor name="loginInterceptor" class="com.interceptors"></interceptor>  
  5.     </interceptors>  
  6.       
  7.     <action name="UserAction" class="com.actions.UserAction">  
  8.     //引用此拦截器,表明拦截器对此Action有效  
  9.     <interceptor-ref name="loginInterceptor"><interceptor-ref>  
  10.     </action>  
  11. </package>  


从配置看来,interceptor只能拦截Action不能拦截其他请求,比如.jsp.txt.jsp。而过滤器则能。因为在过滤策略上Fielter采用访问路径的方式配置。


0 0
原创粉丝点击