注:defaultStack是每个<action/>默认的拦截器栈。然而当用户在<action>中放入了自定义的拦截器的时候,就必须再显式的放入defaultStack。
struts2之所以能在Action类里能做那么多功能,就是依赖于其默认的拦截器栈里定义的各种拦截器。
用户可以配置自己的拦截器栈作为默认的拦截器栈:
只需将配置中的注释解开,<action/>配置里的<interceptor/>也就无需写了。此时自定义的myStack代替了defaultStack拦截器栈
实际开发中,往往配置多个拦截器栈,配置于不同业务模块的<action/>中。
但是注意默认的拦截器栈只能是一个。
2.
方法过滤拦截器
默认情况下我们为某个Action定义了拦截器,则这个拦截器会拦截该Action的所有方法。有些情况下,我们无需拦截所有的方法,此时就需要使用方法过滤拦截器。
方法过滤拦截器使用方法与普通的拦截器没什么区别:
方法过滤拦截器类继承MethodFilterInterceptor
重写的是doIntercept(ActionInvocation invacation)方法
<action/>配置中:
<!--放入上面自定义的拦截器-->
<interceptor-ref name="isLogin">
<!-- 指定login和register方法不需要被拦截-->
<param name="excludeMethods">login,register</param>
<!-- 指定execute方法需要被拦截-->
<param name="includeMethods">execute</param>
</interceptor>
分享到:
相关推荐
简单理解Struts2中拦截器与过滤器的区别及执行顺序
Struts 2 过滤器和拦截器的区别
struts2 trim拦截器 过滤首尾空格
Struts2拦截器实现权限控制demo,我感觉对初学者还是有一定帮助的
struts2工作原理及拦截器和过滤器
用struts2拦截器实现输入数据过滤前后空格
NULL 博文链接:https://takeme.iteye.com/blog/1651479
Struts2编写的通用的禁止用户非法访问非登录页面以外的其他页面的拦截器,过滤器,程序附带运行说明和可执行文件,希望给您的工作或学习带来帮助
Struts2拦截器的实现原理(csdn)————程序
NULL 博文链接:https://1601844782.iteye.com/blog/2275685
通过web配置拦截器进行struts2漏洞拦截源码及配置
• 客户端产生一个HttpServletRequest的请求,该请求被提交到一系列的标准过滤器(Filter)组建链中(如ActionContextCleanUp:它主要是清理当前线程的ActionContext、Dispatcher,FilterDispatcher主要是通过...
拦截器可以说相当于是个过滤器:就是把你不想要的或不想显示的内容给过滤掉。拦截器可以抽象出一部分代码可以用来完善原来的Action。同时可以减轻代码冗余,提高重用率。比如在登入一个页面时,如果要求用户密码、权限...
主要介绍了struts2过滤器和拦截器的区别,简单分析了struts2框架中过滤器和拦截器的概念与相关使用区别,需要的朋友可以参考下
struts2中过滤器的案例,里包含web.xml,struts.xml,以及相关的java文件和jsp文件等,里的程序都可成功执行
学习常用知识(java,sql,oracle,ejb,ssh,struts,xml,监听器,拦截器,过滤器等等)这些都是本人的学习心得非常适用,希望能该初学者带来更大的帮助!!!
以上的这些功能,通过一种名为责任链或者拦截器或者过滤器(语义上的区别而技术上没有什么区别,知道做了什么就行了)的设计模式可以实现,那么就来看看什么是责任链的设计模式。 以下内容参考北京尚学堂的马士兵...
2、拦截器不依赖于servlet容器,通过动态代理实现,过滤器依赖于servlet容器 3、拦截器在方法前后,异常前后等调用,而过滤器只能在请求前和请求后各调一次。 4、拦截器可以利用依赖注入,因此在spring框架程序中,...
(2)拦截器组件可以继承AbstractIntercepter类(实现了Intercepter接口)。 (3)拦截器组件可以继承MethodFilterIntercepter类(继承自AbstractIntercepter),增加了方法过滤功能(上面两种方式是拦截所有方法,这个...