做一个登录验证的页面,对集成admin的所有package进行保护。
<interceptors>
<interceptor name="adminLoginInterceptor"
class="interceptor.AdminLoginInterceptor" >
<param name="pass0">6B8E49836C0C29251833227E3B0F7FB7F8DC67CE</param>
</interceptor>
</interceptors>
<default-interceptor-ref name="adminLoginInterceptor" />
然而发现所有带有传递参数的均无法正常使用了,在Action中所有的参数无法被注入。
最后发现,struts-default中,默认的拦截器引用是defaultstack,这个拦截器包传说是经过精心设计的。。所以会把所有的参数注入!。。。
因此要更改默认拦截器,需要加上这个defaultstack
<package name="admin" extends="struts-default" >
<interceptors>
<interceptor name="adminLoginInterceptor"
class="interceptor.AdminLoginInterceptor" >
<param name="pass0">6B8E49836C0C29251833227E3B0F7FB7F8DC67CE</param>
</interceptor>
<interceptor-stack name="adminstack">
<interceptor-ref name="adminLoginInterceptor"></interceptor-ref>
<interceptor-ref name="defaultStack"></interceptor-ref>
</interceptor-stack>
</interceptors>
<default-interceptor-ref name="adminstack" />
<global-results>
<result name="login">/admin/login.jsp</result>
</global-results>
</package>
<default-interceptor-ref name="adminstack" />
<global-results>
<result name="login">/admin/login.jsp</result>
</global-results>
</package>
特别注意红色两行的顺序!先自定义再Default
===================================以上是转自别人博客===============================
延伸到自己遇到的问题
场景:我自定义了一个拦截器,是为了拦截某个固定的action,所以没有放到默认拦截器栈中,添加到某个需要被拦截的action配置文件中。但是添加拦截器之后,在action中无法注入参数,通过get方法取不到了。
配置如下:
--------struts.xml-------
<interceptors>
<interceptor name="sessionCheck" class="com.wac.common.web.interceptor.WebCookiesInterceptor" />
<interceptor name="loginCheck" class="com.wac.common.web.interceptor.LoginInterceptor" />
<interceptor name="loggingStack" class="com.wac.common.web.interceptor.LoggingInterceptor" />
<interceptor name="inch" class="financeInterfInterceptor"/>
<interceptor name="signAuthJSONInterceptor" class="com.wacai.common.web.interceptor.SignAuthJSONInterceptor"></interceptor>
<interceptor name="signAuthHtmlInterceptor" class="com.wacai.common.web.interceptor.SignAuthHttpInterceptor"></interceptor>
<interceptor-stack name="myStack">
<interceptor-ref name="sessionCheck" />
<interceptor-ref name="loginCheck" />
<interceptor-ref name="loggingStack" />
<interceptor-ref name="defaultStack" />
<interceptor-ref name="inch" />
</interceptor-stack>
</interceptors>
<default-interceptor-ref name="myStack" />
固定的需要拦截的action配置文件struts-manage.xml
<!-- 账户赠送forward -->
<action name="send_gift" class="com.wacai.payment.management.channel.action.AssetManagementAction" method="doSendGift">
<interceptor-ref name="signAuthJSONInterceptor"></interceptor-ref>
<interceptor-ref name="defaultStack"/>
</action>
其中<interceptor-ref name="defaultStack"/>这段添加后,action中的参数就能获取了!
相关推荐
Struts2_自定义拦截器 struts2_3500_my_interceptor
JSP 开发之Struts2内建自定义拦截器.docx
struts2的自定义拦截器代码
struts2的自定义拦截器代码例子
strut2 配置自定义拦截器 包括struts2.xml 和 action对应的xml 以及拦截器 可能有点简单 但是基本配置都有
struts2的一个简单的拦截器例子
简单的struts2自定义拦截器 很适合web初学者
Struts2.3.6实现自定义拦截器Interceptor http://blog.csdn.net/alanchen520/article/details/34086699
Struts2全局、局部自定义拦截器源码。
1.eclipse环境下运行 2.源码 3.自定义拦截器,对用户权限认证 4.各个action之间的跳转
该例子为struts2注解与拦截器demo,利用myEclipse8.5开发,导入刚才后,自动加载所需struts2的jar包,可以直接运行,是初学struts2注解、拦截器很好的例子,保证10分钟学会2种技术,愿意分享给大家。
struts2自定义拦截器.pdf
通过struts2来自定义一个拦截器,需要定义struts2.xml和web.xml文件,详细代码见下载。
自定义的简单的struts,自己写一个和struts一样的xml文件,利用反射进行生成实例和注入参数,自定义拦截器和action
由于struts2标签的性能不好,项目组决定不使用,但是如果用struts2自带的拦截器防止重复提交又必须struts标签,所以只好自定拦器实现
http://blog.csdn.net/zhiweiv/archive/2008/09/19/2954047.aspx
Struts2拦截器(Interceptor) Struts2拦截器(Interceptor)
Struts2自定义拦截器实现防止重复提交