AspectJ实现aop

作者: 妍倩倩 | 来源:发表于2016-09-11 16:06 被阅读18次

    定义Aspect切面,配置对com.java.gk.springaop.SpringAopDemo的方法进行拦截处理

    package com.java.gk.springaop;
    
    import org.aspectj.lang.JoinPoint;
    import org.aspectj.lang.ProceedingJoinPoint;
    import org.aspectj.lang.annotation.After;
    import org.aspectj.lang.annotation.AfterReturning;
    import org.aspectj.lang.annotation.AfterThrowing;
    import org.aspectj.lang.annotation.Around;
    import org.aspectj.lang.annotation.Aspect;
    import org.aspectj.lang.annotation.Before;
    import org.aspectj.lang.annotation.Pointcut;
    
    @Aspect
    public class SpringAop {
        
        /** 
         * Pointcut 
         * 定义Pointcut,Pointcut的名称为aspectjMethod(),此方法没有返回值和参数 
         * 该方法就是一个标识,不进行调用 
         */  
    //  @Pointcut("execution (* com.java.gk.springaop..*.*(..))")
        @Pointcut("execution (* com.java.gk.springaop.SpringAopDemo.*(..))")
        private void aspectjMethod() {
            
        }
        
        /**  
         * Before 
         * 在核心业务执行前执行,不能阻止核心业务的调用。 
         * @param joinPoint  
         */    
        @Before("aspectjMethod()")
        public void beforeAdvice(JoinPoint joinPoint) {
            System.out.println("-----beforeAdvice().invoke-----");  
            System.out.println(" 此处意在执行核心业务逻辑前,做一些安全性的判断等等");
            System.out.println(joinPoint.getTarget().getClass().getName());
            System.out.println(" 可通过joinPoint来获取所需要的内容");  
            System.out.println("-----End of beforeAdvice()------");
        }
        
        /**  
         * After  
         * 核心业务逻辑退出后(包括正常执行结束和异常退出),执行此Advice 
         * @param joinPoint 
         */  
        @After("aspectjMethod()")
        public void afterAdvice(JoinPoint joinPoint) {
            System.out.println("-----afterAdvice().invoke-----");  
            System.out.println(" 此处意在执行核心业务逻辑之后,做一些日志记录操作等等");  
            System.out.println(" 可通过joinPoint来获取所需要的内容");  
            System.out.println("-----End of afterAdvice()------");  
        }
        
        /**  
         * Around  
         * 手动控制调用核心业务逻辑,以及调用前和调用后的处理, 
         *  
         * 注意:当核心业务抛异常后,立即退出,转向AfterAdvice 
         * 执行完AfterAdvice,再转到ThrowingAdvice 
         * @param pjp 
         * @return 
         * @throws Throwable 
         */   
        @Around("aspectjMethod()")
        public Object aroundAdvice(ProceedingJoinPoint proceedingJoinPoint) throws Throwable {
            System.out.println("-----aroundAdvice().invoke-----");
            System.out.println(" 此处可以做类似于Before Advice的事情");
            //调用核心逻辑  
            Object retVal = proceedingJoinPoint.proceed();
            
            System.out.println(" 此处可以做类似于After Advice的事情");
            System.out.println("-----End of aroundAdvice()------");
            return retVal;
        }
        
        /**  
         * AfterReturning  
         * 核心业务逻辑调用正常退出后,不管是否有返回值,正常退出后,均执行此Advice 
         * @param joinPoint 
         */   
        @AfterReturning(value = "aspectjMethod()", returning = "retVal")    
        public void afterReturningAdvice(JoinPoint joinPoint, String retVal) {    
            System.out.println("-----afterReturningAdvice().invoke-----");  
            System.out.println("Return Value: " + retVal);   
            System.out.println(" 此处可以对返回值做进一步处理");  
            System.out.println(" 可通过joinPoint来获取所需要的内容");  
            System.out.println("-----End of afterReturningAdvice()------");  
        }  
          
        /** 
         * 核心业务逻辑调用异常退出后,执行此Advice,处理错误信息 
         *  
         * 注意:执行顺序在Around Advice之后 
         * @param joinPoint 
         * @param ex 
         */  
        @AfterThrowing(value = "aspectjMethod()", throwing = "ex")    
        public void afterThrowingAdvice(JoinPoint joinPoint, Exception ex) {    
            System.out.println("-----afterThrowingAdvice().invoke-----");  
            System.out.println(" 错误信息:"+ex.getMessage());  
            System.out.println(" 此处意在执行核心业务逻辑出错时,捕获异常,并可做一些日志记录操作等等");  
            System.out.println(" 可通过joinPoint来获取所需要的内容");  
            System.out.println("-----End of afterThrowingAdvice()------");    
        }    
        
    }
    

    需要在spring配置文件中配置bean

    <bean id="springAop"  class="com.java.gk.springaop.SpringAop"/>
    

    相关文章

      网友评论

        本文标题:AspectJ实现aop

        本文链接:https://www.haomeiwen.com/subject/ubmuettx.html