快速业务通道

如何在基于注解风格的Spring-MVC中使用拦截器 - 编程入门网

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-06-21

如何在基于注解风格的Spring-MVC中使用拦截器

时间:2011-01-06 BlogJava Atea

Spring-MVC如何使用拦截器,官方文档只给出了非注解风格的例子。那么基于注解风格如何使用拦截器呢?

基于注解基本上有2个可使用的定义类,分别是DefaultAnnotationHandlerMapping和AnnotationMethodHandlerAdapter:

<bean class="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping"/> <bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"/>

1、DefaultAnnotationHandlerMapping

DefaultAnnotationHandlerMapping本身支持自定义拦截器,只需按如下进行配置:

1 <bean class="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping"> 2     <property name="interceptors"> 3         <list> 4                <bean class="packageName.XXXInterceptor" /> 5         </list> 6     </property> 7 </bean>

Interceptor的定义为:

 1 public class XXXInterceptor extends HandlerInterceptorAdapter { 2     @Override 3     public boolean preHandle(HttpServletRequest req, HttpServletResponse resp, Object handler) { 4 5         String className = handler.getClass().getName();// packageName.ClassName 6         if (Error) { 7             return false; 8         } 9         return true; 10     } 11 }

2、AnnotationMethodHandlerAdapter

目前,笔者没找到如何给AnnotationMethodHandlerAdapter配置自定义Interceptor的方法,但是有个customArgumentResolver可以利用一下,来充当Interceptor。

1 <bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"> 2     <property name="customArgumentResolver"> 3         <bean class="packageName.XXXResolver"/> 4     </property> 5 </bean>

Resolver的定义为:

 1 public class XXXResolver implements WebArgumentResolver { 2 3     @Override 4     public Object resolveArgument(MethodParameter methodParameter, NativeWebRequest webRequest) throws Exception { 5 6         String className = methodParameter.getMethod().getDeclaringClass().getName();// packageName.ClassName 7 8         // 如何取得Response和Request 9         HttpServletResponse resp = (HttpServletResponse) webRequest.getNativeResponse(); 10        HttpServletRequest req = (HttpServletRequest) webRequest.getNativeRequest(); 11 12        if (Error) { 13            if (!resp.isCommitted()) resp.sendError(ERROR_STATUS); 14        } 15        return UNRESOLVED; 16     } 17 } 18

仔细的人会看出,第二种方法其实根本不是拦截。其实第二种只是在映射Controller,调用方法的时候,给每一个方法的参数增加了一个切点。

上例在出错的时候往HttpServletResponse写错误状态,来通知web容器进行错误重定向,达到了拦截器的作用。

这么做有一个缺点,就是每个参数都有自己的切点,比如方法有3个参数就会调3次resolveArgument。为了避免出错,需要判断一下resp.isCommitted。

customArgumentResolver的初衷不是用来做Interceptor的,但有些环境却不得不使用它,比如部署在GAE上。

GAE是不支持DefaultAnnotationHandlerMapping的,因为此类用到了org.springframework.beans.BeanUtils.findEditorByConvention,这个方法会调用java.lang.ClassLoader.getSystemClassLoader,而这正是GAE所不允许的。

PS:

文中提到软件的版本:

spring - 2.5.X

google app engine - 1.2.5

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号