struts2常用的预定义拦截器
2012-12-07 09:37
260 查看
1:params拦截器
这个拦截器是必不可少的,因为就是由它偷偷的把请求参数设置到相应的Action的属性去的,并自动进行类型转换。
2:staticParams拦截器
将struts.xml配置文件里定义的Action参数,设置到对应的Action实例中,Action参数使用<param>标签,是<action>标签的子元素。
struts.xml的示例如下:
<action name="helloworldAction" class="cn.javass.action.action.HelloWorldAction">
<param name="account">test</param>
</action>
这要求Action中一定要有一个account的属性,并有相应的getter/setter方法。运行的时候,Action的account属性在初始化过后,会接到这里的赋值“test”。
注意:params拦截器和staticParams拦截器都会为Action的属性赋值,如果碰到了都要赋同一个值呢,比如request里面有account参数,而struts.xml中也有account参数,最终的值是谁?
其实是Action初始化过后,就会把struts.xml中配置的数据设置到Action实例中相应的属性上去。然后,把用户请求的数据设置到Action实例中相应的属性上去。
很明显最后的值是用户请求中account的数据。
3:prepare拦截器
在Action执行之前调用Action的prepare()方法,这个方法是用来准备Action执行之前要做的工作。它要求我们的Action必需实现com.opensymphony.xwork2.Preparable接口
4:modelDriven拦截器
如果Action实现ModelDriven接口,它将getModel()取得的模型对象存入OgnlValueStack中。
5:chain拦截器
将前一个执行结束的Action属性设置到当前的Action中。它被用在ResultType为“chain”所指定的结果的Action中,该结果Action对象会从值栈中获得前一个Action对应的属性,它实现Action链之间的数据传递。
6:execption拦截器
顾名思义,在抛出异常的时候,这个拦截器起作用。它是我们第五章讲的Struts2的错误处理机制(<exception-mapping>)的基础,任何应用都应该引用这个拦截器,而且引用的时候,最好把它放在第一位,让它能捕获所有的异常。
7:validation拦截器
调用验证框架读取 *-validation.xml文件,并且应用在这些文件中声明的校验。
8:token拦截器
核对当前Action请求(request)的有效标识,防止重复提交Action请求 。使用标签<s:token>可以生成表单令牌,该标签会在session中设置一个预期的值并且在表单中创建一个隐藏的input字段。Token拦截器会检查这个令牌,如果不合法,将不会执行action,注意这个拦截器需要手工添加,还需要配置一个invalid.token的result。
9:tokenSession拦截器
扩展了token拦截器的功能,当提交无效的Action请求标识时,它会跳转回到第一次成功后的页面。
10:conversionError拦截器
用来处理框架进行类型转化(Type Conversion)时的出错信息。它将存储在ActionContext中的类型转化(Type Conversion)错误信息转化成相应的Action字段的错误信息,保存在堆栈中。根据需要,可以将这些错误信息在视图中显示出来
11:fileUpload拦截器
用来处理文件上传
12:workflow拦截器
Action默认的工作流,如果action实现了Validateable接口,那么interceptor会调用action的validate()方法;如果action实现了ValidationAware接口,那么interceptor将会检查action是否包含错误信息。如果包含任何错误信息,那么interceptor将会返回input,而不让action执行。
13:servletConfig拦截器
这个拦截器提供Action直接对Servlet API的访问,把Servlet API的对象注入到Action中。包括:ServletRequestAware、ServletResponseAware、ParameterAware、SessionAware、ApplicationAware。
14:timer拦截器
记录ActionInvocation余下部分执行的时间,并做为日志信息记录下来,便于寻找性能瓶颈。
15:logger拦截器
在日志信息中输出要执行的Action信息 ,这样,在调试的时候,就能很快的定位到这个对应的Action了。
先看这么多,其他的预定义拦截器,随着后面的学习再慢慢的展开。
这个拦截器是必不可少的,因为就是由它偷偷的把请求参数设置到相应的Action的属性去的,并自动进行类型转换。
2:staticParams拦截器
将struts.xml配置文件里定义的Action参数,设置到对应的Action实例中,Action参数使用<param>标签,是<action>标签的子元素。
struts.xml的示例如下:
<action name="helloworldAction" class="cn.javass.action.action.HelloWorldAction">
<param name="account">test</param>
</action>
这要求Action中一定要有一个account的属性,并有相应的getter/setter方法。运行的时候,Action的account属性在初始化过后,会接到这里的赋值“test”。
注意:params拦截器和staticParams拦截器都会为Action的属性赋值,如果碰到了都要赋同一个值呢,比如request里面有account参数,而struts.xml中也有account参数,最终的值是谁?
其实是Action初始化过后,就会把struts.xml中配置的数据设置到Action实例中相应的属性上去。然后,把用户请求的数据设置到Action实例中相应的属性上去。
很明显最后的值是用户请求中account的数据。
3:prepare拦截器
在Action执行之前调用Action的prepare()方法,这个方法是用来准备Action执行之前要做的工作。它要求我们的Action必需实现com.opensymphony.xwork2.Preparable接口
4:modelDriven拦截器
如果Action实现ModelDriven接口,它将getModel()取得的模型对象存入OgnlValueStack中。
5:chain拦截器
将前一个执行结束的Action属性设置到当前的Action中。它被用在ResultType为“chain”所指定的结果的Action中,该结果Action对象会从值栈中获得前一个Action对应的属性,它实现Action链之间的数据传递。
6:execption拦截器
顾名思义,在抛出异常的时候,这个拦截器起作用。它是我们第五章讲的Struts2的错误处理机制(<exception-mapping>)的基础,任何应用都应该引用这个拦截器,而且引用的时候,最好把它放在第一位,让它能捕获所有的异常。
7:validation拦截器
调用验证框架读取 *-validation.xml文件,并且应用在这些文件中声明的校验。
8:token拦截器
核对当前Action请求(request)的有效标识,防止重复提交Action请求 。使用标签<s:token>可以生成表单令牌,该标签会在session中设置一个预期的值并且在表单中创建一个隐藏的input字段。Token拦截器会检查这个令牌,如果不合法,将不会执行action,注意这个拦截器需要手工添加,还需要配置一个invalid.token的result。
9:tokenSession拦截器
扩展了token拦截器的功能,当提交无效的Action请求标识时,它会跳转回到第一次成功后的页面。
10:conversionError拦截器
用来处理框架进行类型转化(Type Conversion)时的出错信息。它将存储在ActionContext中的类型转化(Type Conversion)错误信息转化成相应的Action字段的错误信息,保存在堆栈中。根据需要,可以将这些错误信息在视图中显示出来
11:fileUpload拦截器
用来处理文件上传
12:workflow拦截器
Action默认的工作流,如果action实现了Validateable接口,那么interceptor会调用action的validate()方法;如果action实现了ValidationAware接口,那么interceptor将会检查action是否包含错误信息。如果包含任何错误信息,那么interceptor将会返回input,而不让action执行。
13:servletConfig拦截器
这个拦截器提供Action直接对Servlet API的访问,把Servlet API的对象注入到Action中。包括:ServletRequestAware、ServletResponseAware、ParameterAware、SessionAware、ApplicationAware。
14:timer拦截器
记录ActionInvocation余下部分执行的时间,并做为日志信息记录下来,便于寻找性能瓶颈。
15:logger拦截器
在日志信息中输出要执行的Action信息 ,这样,在调试的时候,就能很快的定位到这个对应的Action了。
先看这么多,其他的预定义拦截器,随着后面的学习再慢慢的展开。
相关文章推荐
- stuts2学习笔记------指定需要struts2处理的请求后缀&细说常量定义&常用常量介绍
- Struts2通过自己定义拦截器实现登录之后跳转到原页面
- Struts2他们拦截器实例定义—登陆权限验证
- struts2中定义拦截器对访问权限进行控制
- 力所能及之struts2 拦截器定义的包不同是不是也要在其他包定义拦截器
- 教你如何使用Struts2拦截器并且定义自己的拦截器
- struts2_11_实现自己的拦截器的定义
- Struts2自己定义拦截器实例—登陆权限验证
- Struts2:MyEclippse中使用struts-default.xml中定义的拦截器(timmer,logger)
- struts2常量定义及常用常量
- struts2的拦截器(3):通过实现Interceptor接口定义自己的拦截器
- Struts2自己定义拦截器实例—登陆权限验证
- Struts2常用拦截器
- struts2常量定义及常用常量
- struts2中如何定义拦截器
- struts2 lesson six struts2中的拦截器,过滤器,自定义拦截器,使用拦截器解决表单重复提交,常用标签的使用
- Struts2 拦截器 默认Action 一些常量的设置 Result常用的结果类型
- Struts2自己定义拦截器实例—登陆权限验证
- Struts2的标签及其自定义token拦截器的定义及配置
- struts2拦截器定义