- 浏览: 1171563 次
- 性别:
- 来自: 上海
文章分类
- 全部博客 (411)
- ASP (6)
- ASP.NET (2)
- CSS (4)
- HTML (11)
- Javascript (34)
- Java (100)
- PHP (1)
- XML (2)
- Flash/Flex/AS (1)
- 编程理论 (6)
- 操作系统 (23)
- 架构与搭建 (13)
- 软件应用 (39)
- 移动开发及应用 (4)
- UI设计 (2)
- 数据库 (23)
- 围棋 (1)
- 闲语茶楼 (6)
- 金融 (1)
- 其他 (3)
- Linux/Unix (38)
- 项目管理 (3)
- cmd (2)
- ssh (3)
- SVN (1)
- 移动开发 (1)
- HTML5 (1)
- jquery (1)
- redis (1)
- nginx (2)
- webservice (1)
- vmware (1)
- ssl (1)
- eclipse (1)
- sqlite (1)
- spring (2)
最新评论
-
cnhome:
Java 8 下:// 编码String asB64 = Ba ...
不要使用sun.misc.BASE64Encoder -
请叫我翠西狗:
那如果我要用this.getServletContext() ...
JSP/Servlet使用代理或路由器映射时获取服务器地址为内网地址 -
nomblouder:
按照别的博客,别名一直是p4merge,导致一直报错comma ...
win与linux下git配置p4merge为合并比较工具的方法 -
linuxzhang:
请问我按你的方法修改了sts-3.7.3.RELEASE中的o ...
Eclipse中setter/getter方法自动添加属性注释 -
yzh__:
求解答。。。
Struts2定义默认拦截器时需要注意
最近用Struts2做一个新项目
在做后台的时候,考虑到登陆权限的验证可以使用拦截器来方便实现
于是在后台管理的Action包中定义了一个默认的拦截器
代码如下:
在未登录的情况下尝试了一下验证效果,果然很方便
但是在我登陆后,居然报了以下异常:
查看了一下报异常的位置,正好是我使用ServletRequestAware接口获得request对象的地方。结果测试下来,果然是request返回为空
于是想到了Struts2的这些接口中给出的对象好像都是通过他的默认拦截器注入的,我现在在包中定义的默认拦截器看来是把Struts2的默认拦截器给替代了,它没有默认继承下来
没办法,最后只好尝试把Struts2的默认拦截器和自己定义的权限拦截器定义成一个拦截器栈,把拦截器栈作为后台的默认拦截器后,终于回归正常,异常消失
配置代码如下:
所以请大家需要设置默认拦截器的时候,一定要注意阿,如果Action有注入的对象,务必要把Struts2的默认拦截器也一起配置进入
另外,我用的是Struts2.1.6的版本,我不知道这是Struts2故意这么设定的,还是算是一个bug,从理论上来说,貌似这是一个合理的异常,不属于bug。。。
对了,该版本另外有一个bug就是当被配置为开发模式的时候,项目路径就不能包含空格,否则也会报异常的。。。
这个bug具体的可以看这篇文章:
http://fableking.iteye.com/blog/383928
在做后台的时候,考虑到登陆权限的验证可以使用拦截器来方便实现
于是在后台管理的Action包中定义了一个默认的拦截器
代码如下:
<!-- 后台管理 --> <package name="admin" namespace="/admin" extends="struts-default"> <interceptors> <interceptor name="adminAuthentication" class="org.jesselu.coco.action.interceptor.AdminAuthenticationInterceptor"></interceptor> </interceptors> <default-interceptor-ref name="adminAuthentication"></default-interceptor-ref> <global-results> <result name="login" type="redirect">/admin/login.jsp</result> </global-results> <action name="goodsList" class="org.jesselu.coco.action.admin.GoodsListAction"> <result>/admin/detail/goodsList.jsp</result> </action> </package>
在未登录的情况下尝试了一下验证效果,果然很方便
但是在我登陆后,居然报了以下异常:
Stacktraces java.lang.NullPointerException org.jesselu.coco.action.admin.GoodsListAction.execute(GoodsListAction.java:31) sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) java.lang.reflect.Method.invoke(Method.java:585) com.opensymphony.xwork2.DefaultActionInvocation.invokeAction(DefaultActionInvocation.java:440) com.opensymphony.xwork2.DefaultActionInvocation.invokeActionOnly(DefaultActionInvocation.java:279) com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:242) org.jesselu.coco.action.interceptor.AdminAuthenticationInterceptor.intercept(AdminAuthenticationInterceptor.java:27) com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:236) org.apache.struts2.impl.StrutsActionProxy.execute(StrutsActionProxy.java:52) org.apache.struts2.dispatcher.Dispatcher.serviceAction(Dispatcher.java:468) org.apache.struts2.dispatcher.FilterDispatcher.doFilter(FilterDispatcher.java:395) org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:215) org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:188) org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:96) org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:76) org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:215) org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:188) org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:213) org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:174) org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127) org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:117) org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:108) org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:174) org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:874) org.apache.coyote.http11.Http11BaseProtocol$Http11ConnectionHandler.processConnection(Http11BaseProtocol.java:665) org.apache.tomcat.util.net.PoolTcpEndpoint.processSocket(PoolTcpEndpoint.java:528) org.apache.tomcat.util.net.LeaderFollowerWorkerThread.runIt(LeaderFollowerWorkerThread.java:81) org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run(ThreadPool.java:689) java.lang.Thread.run(Thread.java:595)
查看了一下报异常的位置,正好是我使用ServletRequestAware接口获得request对象的地方。结果测试下来,果然是request返回为空
于是想到了Struts2的这些接口中给出的对象好像都是通过他的默认拦截器注入的,我现在在包中定义的默认拦截器看来是把Struts2的默认拦截器给替代了,它没有默认继承下来
没办法,最后只好尝试把Struts2的默认拦截器和自己定义的权限拦截器定义成一个拦截器栈,把拦截器栈作为后台的默认拦截器后,终于回归正常,异常消失
配置代码如下:
<!-- 后台管理 --> <package name="admin" namespace="/admin" extends="struts-default"> <interceptors> <interceptor name="adminAuthentication" class="org.jesselu.coco.action.interceptor.AdminAuthenticationInterceptor"></interceptor> <interceptor-stack name="adminInterceptor"> <interceptor-ref name="adminAuthentication"></interceptor-ref> <interceptor-ref name="defaultStack"></interceptor-ref> </interceptor-stack> </interceptors> <default-interceptor-ref name="adminInterceptor"></default-interceptor-ref> <global-results> <result name="login" type="redirect">/admin/login.jsp</result> </global-results> <action name="goodsList" class="org.jesselu.coco.action.admin.GoodsListAction"> <result>/admin/detail/goodsList.jsp</result> </action> </package>
所以请大家需要设置默认拦截器的时候,一定要注意阿,如果Action有注入的对象,务必要把Struts2的默认拦截器也一起配置进入
另外,我用的是Struts2.1.6的版本,我不知道这是Struts2故意这么设定的,还是算是一个bug,从理论上来说,貌似这是一个合理的异常,不属于bug。。。
对了,该版本另外有一个bug就是当被配置为开发模式的时候,项目路径就不能包含空格,否则也会报异常的。。。
这个bug具体的可以看这篇文章:
http://fableking.iteye.com/blog/383928
评论
4 楼
yzh__
2016-05-04
求解答。。。
3 楼
yzh__
2016-05-04
博主您好!我也出现了类似的问题,我用拦截器实现ServletRequestAware接口,setServletRequest方法也写了,但在使用request的地方出现了空指针异常,在Action中也显式地启用了系统默认的拦截器栈。
<interceptors>
<interceptor name="autoLogin"class="com.yzh.b2cshop.interceptor.AutoLoginInterceptor"/>
</interceptors>
<action name="index" class="com.yzh.b2cshop.action.index.IndexAction">
<result>/WEB-INF/content/product.jsp</result>
<interceptor-ref name="defaultStack"/>
<interceptor-ref name="autoLogin"/>
</action>
<interceptors>
<interceptor name="autoLogin"class="com.yzh.b2cshop.interceptor.AutoLoginInterceptor"/>
</interceptors>
<action name="index" class="com.yzh.b2cshop.action.index.IndexAction">
<result>/WEB-INF/content/product.jsp</result>
<interceptor-ref name="defaultStack"/>
<interceptor-ref name="autoLogin"/>
</action>
2 楼
kjj
2009-05-18
从webwork时期就这样了,楼主,如果你显式配置,必须都配,他没有默认的配置!!
1 楼
mgoann
2009-05-18
你配置全局拦截器,加上默认是必须得~
发表评论
-
Maven使用mvn命令时跳过test的参数
2015-05-28 11:24 1727方法有两种: 方法1: mvn install -Dsk ... -
Spring中Propagation类的事务属性区别
2014-12-08 14:50 1939PROPAGATION_REQUIRED:支持当前事务,如果 ... -
Spring AOP中pointcut expression表达式解析
2014-08-27 15:39 3421Pointcut 是指那些方法需要被执行"AOP& ... -
用正则表达式替换手机号为星号*的写法
2014-08-11 15:43 10041现在网络越来越关注一些隐私,比如手机号隐藏当中的若干位数字 ... -
java使用相对路径连接sqlite
2014-08-01 15:48 6915在sqlite的连接源码中,可以看到 :resource: ... -
Eclipse中setter/getter方法自动添加属性注释
2014-08-01 12:11 16583这篇文章以前在公司内网发的,到现在也一直有用,发上来分享给有 ... -
memcached-session-manager配置
2014-07-09 18:01 953声明:本篇文章是根据memcach ... -
使用java原生url连接传输protobuf
2014-06-26 18:16 1461protobuf已经出来好多年了,原谅我最近才了解到goo ... -
Tomcat内存、连接数等性能参数设置
2014-02-20 14:37 17101、修改启动时内存参数、并指定JVM时区 (在windows ... -
使用JSP列出所有运行中的线程
2013-07-29 10:06 1044<html> <head> &l ... -
JVM系列五:JVM监测&工具[整理中]
2013-05-10 10:34 1130前几篇篇文章介绍了介绍了JVM的参数设置并给 ... -
JVM系列四:生产环境参数实例及分析【生产环境实例增加中】
2013-05-10 10:32 1255java application项目(非web项目) 改进 ... -
JVM系列三:JVM参数设置、分析
2013-05-10 10:30 1021不管是YGC还是Full GC,GC过程中都 ... -
JVM系列二:GC策略&内存申请、对象衰老
2013-05-10 10:19 1031JVM里的GC(Garbage Collec ... -
JVM系列一:JVM内存组成及分配
2013-05-10 10:14 1093java内存组成介绍:堆(Heap)和非堆(Non-h ... -
jenkins配置权限不对导致无法登陆的重置方法
2013-04-20 20:43 25385找到.jenkins/config.xml文件: 替换为: ... -
Spring3中替换默认拦截器的方法BeanFactoryPostProcessor
2012-08-14 16:51 4052由于Spring默认的静态资源处理器不能满足需求,需要做一些自 ... -
Hessian 权限认证
2012-08-07 11:23 1523Hessian 权限认证 Hessian的一些基本简介已经在上 ... -
利用java 6.0的脚本引擎执行字符串表达式运算
2012-08-06 23:09 1451例子都在这里了:http://www.java2s.com/C ... -
在spring、tomcat中使用多数据源并支持分布式事务管理
2012-08-06 22:10 2624原文:http://zxlaiye.iteye.c ...
相关推荐
- 使用`<default-interceptor-ref>`定义默认拦截器栈,所有未明确指定拦截器的动作都将使用这个栈。 4. **自定义拦截器**: - 创建一个新的Java类,实现`Interceptor`接口并重写`intercept()`方法。 - 在`...
`prepare`拦截器是Struts2框架中的一个默认拦截器,它在执行Action之前进行预处理工作。 `prepare`拦截器的主要职责是确保Action对象在处理请求之前被初始化。在Struts2配置文件中,这个拦截器通常位于默认拦截器栈...
首先,理解拦截器的定义:拦截器是AOP(面向切面编程)的一个概念,在Struts2中,拦截器是基于Java的动态代理机制实现的。它们是一系列实现了`Interceptor`接口的类,可以在Action执行前后插入额外的行为。这些行为...
通过`<package>`标签的`default-interceptor-ref`属性,可以指定默认拦截器栈,或者在具体的Action配置中使用`interceptor-ref`引用特定的拦截器栈。 **5. 拦截器的生命周期** 拦截器的生命周期包括实例化、初始化...
这里,我们创建了一个名为“myStack”的拦截器栈,并在其中添加了默认拦截器栈和我们自定义的`authorization`拦截器。 3. 应用拦截器:接下来,我们需要在Action配置中引用这个拦截器栈。这样,每次请求该Action时...
当请求到达控制器时,Struts2会依次调用这个栈中的拦截器,每个拦截器都有机会处理请求,然后决定是否将请求传递给下一个拦截器或直接返回响应。 创建一个简单的Struts2拦截器,你需要遵循以下步骤: 1. 创建拦截...
默认拦截器栈`defaultStack`包含了Struts2预定义的一些拦截器,如`params`、`i18n`等。在添加自定义拦截器时,可以将其插入到默认拦截器栈中,也可以创建自定义的拦截器栈。 ### 五、测试与优化 完成上述步骤后,你...
Struts2是一个强大的Java web框架,它为开发者提供了丰富的功能,包括类型转换、拦截器和校验机制。本文将深入探讨这些关键知识点,并通过实际例子来帮助你理解它们的工作原理和应用。 首先,我们来看看**类型转换...
在Struts2中,拦截器是基于Java的动态代理机制实现的,它们按照预定义的顺序形成一个拦截器链。当请求到达Action时,这些拦截器会按照顺序逐个执行其`intercept()`方法,最后调用实际的动作方法。拦截器可以独立于...
默认拦截器栈包含了Struts2框架预定义的一些拦截器,如`ExceptionMappingInterceptor`用于处理异常,`PrepareInterceptor`用于准备Action,`ModelDrivenInterceptor`用于模型驱动等。 3. `destroy()`: 这个方法在...
-- 将自定义拦截器添加到默认拦截器栈中 --> <!-- 配置Action使用自定义拦截器栈 --> <result name="profanityError">/errorPage.jsp <!-- 其他结果配置 --> </struts> ``` 在上述配置中,`...
上述代码中,`logging`拦截器会在Action执行前后打印日志,`myStack`拦截器栈包含默认拦截器栈和`logging`拦截器,`someAction`会使用这个拦截器栈。 接下来,我们关注描述中提到的注解使用。Struts2在`...
在这个"struts2的自定义拦截器例子"中,我们将深入探讨如何创建和使用自定义拦截器。 首先,拦截器的本质是Java的面向切面编程(AOP)思想在Struts2中的体现。它们允许开发者在动作执行前后插入自定义的逻辑,例如...
在某些情况下,我们需要在拦截器中处理国际化问题,例如根据用户的选择或浏览器的默认语言动态切换资源包。这时,我们可以编写一个自定义拦截器来实现这一功能: 1. 自定义拦截器中,检查请求头或Cookie以获取用户...
Struts2拦截器是一种AOP(面向切面编程)的实现,它可以在不修改Action代码的情况下,通过定义拦截器并在配置文件中设置拦截器链,来动态地添加或删除功能。拦截器是可插拔的,可以在请求到达Action之前或之后执行...
首先,我们需要了解拦截器在Struts2中的作用。拦截器是AOP(面向切面编程)的一个核心概念,它允许开发者在动作执行前后插入额外的逻辑,如日志记录、权限检查、事务管理等。在Struts2中,拦截器通过...
默认情况下,所有Action都会应用名为`defaultStack`的默认拦截器栈。如果你需要添加自定义拦截器,可以显式地引用它们。 ```xml <result>success.jsp ``` 在上述配置中,`someAction`会先经过`...
-- 其他默认拦截器 --> <result name="success">/success.jsp <result name="invalid">/error.jsp ``` 至此,你已经掌握了Struts2拦截器的基本使用。实际开发中,你可以根据项目需求灵活组合和扩展拦截...
在Struts2的配置文件(通常为struts.xml或struts-default.xml)中,通过`<interceptors>`标签定义拦截器栈,再通过`<action>`标签的`interceptor-ref`属性引用拦截器栈。例如: ```xml ...