关闭

自定义注解实现spring 方法拦截用于日志,等处理

标签: 拦截器springmethodIntercept自定义aop
512人阅读 评论(0) 收藏 举报
分类:


老规矩:配置文件去掉了左右尖括号
配置文件:
      bean id="seInterceptor" class="com.web.util.SeInterceptor"  /bean
    aop:config 
             
                 aop:pointcut id="loginPoint" 
                 expression="execution(public * com.web.controller.*.*(..)) "/

                 aop:advisor pointcut-ref="loginPoint" advice-ref="seInterceptor"/
      /aop:config
    自定义注解:
package com.web.util;  
  
import java.lang.annotation.Documented;  
import java.lang.annotation.ElementType;  
import java.lang.annotation.Retention;  
import java.lang.annotation.RetentionPolicy;  
import java.lang.annotation.Target;  
@Target(ElementType.METHOD)  
@Retention(RetentionPolicy.RUNTIME)  
@Documented  
public abstract @interface RequiredInterceptor{  
    boolean required() default true;  
}  
controller:
package com.web.util;  
  
import org.aopalliance.intercept.MethodInterceptor;  
import org.aopalliance.intercept.MethodInvocation;  
import org.springframework.core.annotation.AnnotationUtils;  
  
public class SeInterceptor implements MethodInterceptor {  
    @Override  
    public Object invoke(MethodInvocation invocation) throws Throwable { 
     System.out.println("------invoke-----");
        RequiredInterceptor requiredInterceptor = AnnotationUtils.findAnnotation(invocation.getMethod(), RequiredInterceptor.class);  
        if(requiredInterceptor!=null){  
            System.out.println(invocation.getMethod().getName());  
        }  
      return invocation.proceed();  
    }  
  

}  

需要的jar包:spring基本jar包,另外:aspectjweaver-1.8.7.jar   aspectjrt-1.8.6.jar   commons-logging-1.1.1.jar

1
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:16088次
    • 积分:497
    • 等级:
    • 排名:千里之外
    • 原创:32篇
    • 转载:2篇
    • 译文:0篇
    • 评论:1条
    文章分类
    最新评论