通知可以根据切入点表达式来进行增强,也可以根据自己的注解值来进行增强

通知可以根据切入点表达式来进行增强,也可以根据自己的注解值(例如 @Before@After@Around 等)来进行增强。

如果要根据切入点表达式来进行增强,需要在通知注解中使用 @Pointcut 注解来引用切入点表达式。例如,在以下示例中,我们使用 @Before@After 注解来分别在方法执行前和执行后增强 SomeService 类中的 doSomething 方法:

@Aspect
@Component
public class SomeAspect {
    
    @Pointcut("execution(* com.example.demo.service.SomeService.doSomething(..))")
    public void doSomethingPointcut() {}

    @Before("doSomethingPointcut()")
    public void beforeDoSomething() {
        System.out.println("before doSomething");
    }
    
    @After("doSomethingPointcut()")
    public void afterDoSomething() {
        System.out.println("after doSomething");
    }
}

如果要根据自己的注解值来进行增强,则可以直接在通知注解中指定增强的类型。例如,在以下示例中,我们使用 @MyLog 注解来标记需要记录日志的方法,在 @MyLog 注解的 value 属性中指定日志类型,然后使用 @Around 注解来拦截该方法并记录日志:

@Aspect
@Component
public class LoggingAspect {
    
    @Around("@annotation(com.example.demo.annotation.MyLog)")
    public Object logMethod(ProceedingJoinPoint joinPoint) throws Throwable {
        String methodName = joinPoint.getSignature().getName();
        String logType = ((MyLog) joinPoint.getTarget().getClass()
                .getMethod(methodName, Arrays.stream(joinPoint.getArgs())
                        .map(Object::getClass).toArray(Class[]::new))
                .getAnnotation(MyLog.class)).value();
        
        System.out.println("start " + logType + " log");
        Object result = joinPoint.proceed();
        System.out.println("end " + logType + " log");
        
        return result;
    }
}

在这个示例中,我们定义了一个 @MyLog 注解,用于标记需要记录日志的方法。@MyLog 注解有一个 value 属性,用于指定日志类型。然后,在 LoggingAspect 类中,我们使用 @Around 注解来拦截标记了 @MyLog 注解的方法,并根据 @MyLog 注解中指定的日志类型来记录日志。

你可能感兴趣的:(java,开发语言)