java中,自定义注解拦截器来实现,在需要的拦截的方法上面加上一个注解@AccessRequired

java中,自定义注解拦截器来实现,在需要的拦截的方法上面加上一个注解@AccessRequired

spring mvc Controller中的使用实例

  1. /** 
  2.      * 注解拦截器方法 
  3.      * @return 
  4.      */  
  5.     @RequestMapping(value="/urlinter",method=RequestMethod.GET)  
  6.     @AccessRequired  
  7.     public @ResponseBody String urlInterceptorTest() {  
  8.         return "通过拦截器:user"+request.getAttribute("currUser");  
  9.     }  

如何实现以上实例呢?

定义一个注解:

  1. import java.lang.annotation.ElementType;  
  2. import java.lang.annotation.RetentionPolicy;  
  3. import java.lang.annotation.Target;  
  4. import java.lang.annotation.Retention;  
  5.   
  6. @Target(ElementType.METHOD)  
  7. @Retention(RetentionPolicy.RUNTIME)  
  8. public @interface AccessRequired {  
  9.       
  10. }  

搞一个拦截器:

  1. /** 
  2.  * 拦截url中的access_token 
  3.  * @author Nob 
  4.  *  
  5.  */  
  6. public class UserAccessApiInterceptor extends HandlerInterceptorAdapter {  
  7.   
  8.     public boolean preHandle(HttpServletRequest request,  
  9.             HttpServletResponse response, Object handler) throws Exception {  
  10.   
  11.         HandlerMethod handlerMethod = (HandlerMethod) handler;  
  12.         Method method = handlerMethod.getMethod();  
  13.         AccessRequired annotation = method.getAnnotation(AccessRequired.class);  
  14.         if (annotation != null) {  
  15.            System.out.println("你遇到了:@AccessRequired");  
  16.            String accessToken = request.getParameter("access_token");  
  17.             /** 
  18.              * Do something 
  19.              */  
  20.             response.getWriter().write("没有通过拦截,accessToken的值为:" + accessToken);  
  21.         }  
  22.         // 没有注解通过拦截  
  23.         return true;  
  24.     }  
  25. }  
在spring mvc配置文件中:

  1. <!-- 拦截器 -->  
  2.     <mvc:interceptors>  
  3.         <mvc:interceptor>  
  4.             <!-- 对所有的请求拦截使用/** ,对某个模块下的请求拦截使用:/myPath/* -->  
  5.             <mvc:mapping path="/api/**" />  
  6.             <ref bean="userAccessInterceptor" />  
  7.         </mvc:interceptor>  
  8.     </mvc:interceptors>  
  9.   
  10.     <bean id="userAccessInterceptor"  
  11.         class="com.banmacoffee.web.interceptor.UserAccessApiInterceptor">  
  12.     </bean>  

注意问题:

    如果你使用了<mvc:resources mapping="/resources/**" location="/resources/" />来配置静态资源,那么配置如上拦截器的时候就要使用使用了全局拦截/**,否则会拦截静态资源抛出ResourceHttpRequestHandler cannot be cast to HandlerMethod异常

办法一:加上拦截路径前缀

  1. <mvc:mapping path="/path/**" />  

<!-- 这里使用一个path前置,如api,否则会拦截静态资源 -->

办法二:在自定义拦截器中使用instanceof 过滤ResourceHttpRequestHandler 类型

大功告成,你可以在拦截器里为所欲为,并且把它加载任何你想的Controller 请求的方法上


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值