struts2拦截器是struts框架的核心功能之一。首先,struts框架所实现的自动数据填充功能就是利用拦截器来实现的。这里主要是来总结一下这段时间学习拦截的器的心得。
很明显拦截器所要做的工作是预处理或者后加工。框架本身所实现的参数填充就是在预处理阶段。类型转换中分别在预处理和后加工阶段进行,在预处理阶段把视图传来的字符串数据转化成相应的java数据类型,在业务处理完成后把结果类型再转化为字符串到达结果页面进行显示。
总结一下个人自定义拦截器的使用方法:
1.首先建立拦截器类来实现拦截器的逻辑功能。必须实现Interceptor接口
2.配置struts.xml来添加拦截器。
3.将拦截器与相应的动作联系在一起。
4.测试拦截器。
这里以我们最常用的身份验证来实现一个自定义的拦截器。
这里首先实现了拦截器类的逻辑功能,Interceptor接口中有三个方法destory、init、intercept三个方法。其中init和destory主要处理初始化和清理资源工作,这里不用进行实现。主要的业务逻辑都放在intercept中,这里主要的逻辑功能是检测用户是否登录,若登录了则invocation.invoke()表明继续执行,若未登录则转到一个公共的视图-Log,这是在struts.xml中声明的一个公共视图,也就是登录界面。
这里主要进行的是配置拦截器,在struts.xml中配置拦截器,就如同生命action相似。这里值得注意的是我们如果自定义了拦截器并且把它与某个动作相关联,那么系统的拦截器就会被默认屏蔽,则struts2的大部分核心工作都没法完成,所以我们的解决办法有两种,一是我们在为每个动作添加拦截器的时候同时添加上系统默认的拦截器;二是我们将系统拦截器与我们自己编写的拦截器一同包装成拦截器栈然后使用。这里我们使用第二种方式,因为这样便于修改和维护。
这里有一个action为DeleteStudent,我们为这个动作添加拦截器,也就是如果你想进行删除学生的操作,你必须有权限,也就是必须登录了。
用<interceptor-ref name="permissionStack"/>这句话将我们封装的拦截器栈与此action联系在一起。这样我们自定义的拦截器就可以正常工作了。如果没有登录,你就没有删除学生的权限。
当然我们也可以使用
<default-interceptor-ref name="permissinStack"/>来使我们自定义的拦截器栈成为默认拦截器,也就是为每个action添加此拦截器栈。
分享到:
相关推荐
Struts2_自定义拦截器 struts2_3500_my_interceptor
struts2的自定义拦截器代码
JSP 开发之Struts2内建自定义拦截器.docx
struts2的自定义拦截器代码例子
Struts2.3.6实现自定义拦截器Interceptor http://blog.csdn.net/alanchen520/article/details/34086699
strut2 配置自定义拦截器 包括struts2.xml 和 action对应的xml 以及拦截器 可能有点简单 但是基本配置都有
struts2的一个简单的拦截器例子
简单的struts2自定义拦截器 很适合web初学者
1.eclipse环境下运行 2.源码 3.自定义拦截器,对用户权限认证 4.各个action之间的跳转
Struts2全局、局部自定义拦截器源码。
struts2自定义拦截器.pdf
Struts2的拦截器——Struts2拦截器的基础知识
Struts2自定义拦截器实现防止重复提交
由于struts2标签的性能不好,项目组决定不使用,但是如果用struts2自带的拦截器防止重复提交又必须struts标签,所以只好自定拦器实现
该例子为struts2注解与拦截器demo,利用myEclipse8.5开发,导入刚才后,自动加载所需struts2的jar包,可以直接运行,是初学struts2注解、拦截器很好的例子,保证10分钟学会2种技术,愿意分享给大家。
通过struts2来自定义一个拦截器,需要定义struts2.xml和web.xml文件,详细代码见下载。
http://blog.csdn.net/zhiweiv/archive/2008/09/19/2954047.aspx
自定义拦截器的实现以及拦截器的详细配置,配置文件里面有特别详细的注释,希望对刚接触拦截器的同学有帮助