什么是拦截器html
拦截器(Interceptor)是Struts 2的一个强有力的工具,有许多功能都是构建于它之上,如国际化(前两篇博客介绍过)、转换器,校验等。java
拦截器是动态拦截Action调用的对象。它提供了一种机制可使开发者能够定义在一个action执行的先后执行的代码,也能够在一个action执行前阻止其执行。同时也是提供了一种能够提取action中可重用的部分的方式。apache
说到拦截器有一个东西不 能落下——拦截器链(Interceptor Chain,在Struts 2中称为拦截器栈Interceptor Stack)。拦截器链就是将拦截器按必定的顺序联结成一条链。在访问被拦截的方法或字段时,拦截器链中的拦截器就会按其以前定义的顺序被调用。cookie
实现原理session
Struts 2的拦截器实现相对简单。当请求到达Struts 2的ServletDispatcher时,Struts 2会查找配置文件,并根据其配置实例化相对的拦截器对象,而后串成一个列表(list),最后一个一个地调用列表中的拦截器。
app
Struts 2提供了丰富多样的,功能齐全的拦截器实现。你们能够到struts2-all-2.0.1.jar或struts2-core-2.0.1.jar包的struts-default.xml查看关于默认的拦截器与拦截器链的配置。
jsp
相关说明以下:ide
拦截器工具 |
名字字体 |
说明 |
Alias Interceptor |
alias |
在不一样请求之间将请求参数在不一样名字件转换,请求内容不变 |
Chaining Interceptor |
chain |
让前一个Action的属性能够被后一个Action访问,如今和chain类型的result()结合使用。 |
Checkbox Interceptor |
checkbox |
添加了checkbox自动处理代码,将没有选中的checkbox的内容设定为false,而html默认状况下不提交没有选中的checkbox。 |
Cookies Interceptor |
cookies |
使用配置的name,value来是指cookies |
Conversion Error Interceptor |
conversionError |
将错误从ActionContext中添加到Action的属性字段中。 |
Create Session Interceptor |
createSession |
自动的建立HttpSession,用来为须要使用到HttpSession的拦截器服务。 |
Debugging Interceptor |
debugging |
提供不一样的调试用的页面来展示内部的数据情况。 |
Execute and Wait Interceptor |
execAndWait |
在后台执行Action,同时将用户带到一个中间的等待页面。 |
Exception Interceptor |
exception |
将异常定位到一个画面 |
File Upload Interceptor |
fileUpload |
提供文件上传功能 |
I18n Interceptor |
i18n |
记录用户选择的locale |
Logger Interceptor |
logger |
输出Action的名字 |
Message Store Interceptor |
store |
存储或者访问实现ValidationAware接口的Action类出现的消息,错误,字段错误等。 |
Model Driven Interceptor |
model-driven |
若是一个类实现了ModelDriven,将getModel获得的结果放在Value Stack中。 |
Scoped Model Driven |
scoped-model-driven |
若是一个Action实现了ScopedModelDriven,则这个拦截器会从相应的Scope中取出model调用Action的setModel方法将其放入Action内部。 |
Parameters Interceptor |
params |
将请求中的参数设置到Action中去。 |
Prepare Interceptor |
prepare |
若是Acton实现了Preparable,则该拦截器调用Action类的prepare方法。 |
Scope Interceptor |
scope |
将Action状态存入session和application的简单方法。 |
Servlet Config Interceptor |
servletConfig |
提供访问HttpServletRequest和HttpServletResponse的方法,以Map的方式访问。 |
Static Parameters Interceptor |
staticParams |
从struts.xml文件中将中的中的内容设置到对应的Action中。 |
Roles Interceptor |
roles |
肯定用户是否具备JAAS指定的Role,不然不予执行。 |
Timer Interceptor |
timer |
输出Action执行的时间 |
Token Interceptor |
token |
经过Token来避免双击 |
Token Session Interceptor |
tokenSession |
和Token Interceptor同样,不过双击的时候把请求的数据存储在Session中 |
Validation Interceptor |
validation |
使用action-validation.xml文件中定义的内容校验提交的数据。 |
Workflow Interceptor |
workflow |
调用Action的validate方法,一旦有错误返回,从新定位到INPUT画面 |
Parameter Filter Interceptor |
N/A |
从参数列表中删除没必要要的参数 |
Profiling Interceptor |
profiling |
经过参数激活profile |
在struts.xml中添加以下配置:
<!-- 配置全局拦截器 -->
<package name="all" extends="struts-default">
<interceptors>
<!-- 定义权限控制拦截器 -->
<interceptor name="authority"
class="akai.cost.ms.base.AuthInterceptor" />
<!-- 定义一个包含权限控制的拦截器栈 -->
<interceptor-stack name="mydefault">
<interceptor-ref name="defaultStack" />
<interceptor-ref name="authority" />
</interceptor-stack>
</interceptors>
<!-- 定义默认拦截器 -->
<default-interceptor-ref name="mydefault" />
<!-- 定义全局处理结果 -->
<global-results>
<!-- 逻辑名为login的结果,映射到/login.jsp页面 -->
<result name="login">/login.jsp</result>
</global-results>
</package>
使用方法:其余包继承这个包名就能够了
<package name="abc" extends="all" namespace="/">
附:拦截器类
annoction注解中使用拦截器和拦截栈
1 //直接在类名称的上端写入便可,value中指定要引入的拦截器的名称便可 2 @InterceptorRef(value="token") 3 //拦截栈的引用,蓝色字体即拦截栈的引用名称 4 @InterceptorRefs(@InterceptorRef("sessionCheckStack"))