AspectJ实现aop

定义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


你可能感兴趣的:(AspectJ实现aop)