Struts2自定义拦截器

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 {}

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

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采用访问路径的方式配置。

你可能感兴趣的:(AOP,struts,String,Interceptor,filter,action)