Spring MVC 注解下Controller 的AOP

http://blog.csdn.net/lxf9601/article/details/5925211


补充:

自己经过本地测试发现,在srpingmvc-servlet中进行@control @aspect的扫描,是可以AOP到com.control的处理的

<context:annotation-config />
<!-- 把标记了@Controller注解的类转换为bean -->
<context:component-scan base-package="com.control" />
<!-- 开启aspetj注解扫描 -->
<aop:aspectj-autoproxy proxy-target-class="true" /> 


在使用spring框架时,通常用它的aop来记录日志,但在spring mvc采用@Controller注解时,对Controller进行Aop拦截不起作用,原因是该注解的Controller已被spring容器内部代理了.

需要对org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter进行Aop才能起作用.经过多次测试可行.

[c-sharp]  view plain copy
  1. package com.autoabacus.dal.controller;  
  2. import org.aspectj.lang.ProceedingJoinPoint;  
  3. import org.aspectj.lang.annotation.Around;  
  4. import org.aspectj.lang.annotation.Aspect;  
  5. import org.springframework.stereotype.Component;  
  6. @Component  
  7. @Aspect  
  8. public class Aop {  
  9.     public Aop() {  
  10.         System.out.println("Aop");  
  11.     }  
  12.     // @Around("within(org.springframework.web.bind.annotation.support.HandlerMethodInvoker..*)")  
  13.     @Around("execution(* org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter.handle(..))")  
  14.     public Object aa(ProceedingJoinPoint pjp)  throws Throwable   
  15.     {  
  16.         try {  
  17.             Object retVal = pjp.proceed();  
  18.             System.out.println(retVal);  
  19.             return retVal;  
  20.         } catch (Exception e) {  
  21.             System.out.println("异常");  
  22.             return null;  
  23.         }  
  24.     }  
  25. }  

Controller代码

[java]  view plain copy
  1. package com.autoabacus.dal.controller;  
  2. import org.springframework.stereotype.Controller;  
  3. import org.springframework.web.bind.annotation.RequestMapping;  
  4. @Controller    
  5. public class WelcomeController {  
  6.     @RequestMapping  
  7.     public void welcome() {  
  8.         if (true)  
  9.             throw new RuntimeException("fdsafds");  
  10.     }    
  11. }  


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值