java - 在带参数的注释之前未调用方面

标签 java aspectj

我在使用 AspectJ 时遇到问题。我在注释中添加了参数,在该注释之前将编织方面,因此它不起作用。

注解接口(interface):

@Target({ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
public @interface Logged {
   Event event();
   System system();
}

我的观点:

@Aspect
@Component
public class Aspect {
    @Pointcut("@annotation(Logged) && args(event, system)")
    public void invoke(Event event, System system) { }

    @Around("invoke(event, system)")
    public void aspectMethod (ProceedingJoinPoint, Event event, System system) {
        System.out.println(event + " " + system);
    }
}

事件和系统是枚举。

并在类似的方法之前添加注释:

@Logged(event = Event.USER_LOGGED, system = System.WIN)
someTestingMethod();

仅当我将 Aspect 保留为:

@Aspect
@Component
public class Aspect {
    @Pointcut("@annotation(Logged)")
    public void invoke() { }

    @Around("invoke()")
    public void aspectMethod (ProceedingJoinPoint) {
        System.out.println("Hey");
    }
}

我不知道如何使用注释将参数传递到 Aspect 中。

最佳答案

基本的解决办法是绑定(bind)注解:

@Aspect
class MyAspect {
    @Pointcut("execution(* *(..)) && @annotation(l)")
    public void invoke(Logged l) {}

    @Around("invoke(l)")
    public void aspectMethod (ProceedingJoinPoint pjp, Logged l) {
        java.lang.System.out.println(l.event()+" "+l.system());
    }
}

我使用execution()切入点仅选择方法(因此我们需要带注释的方法),否则它将绑定(bind)注释的其他用户(在字段/类型/等上)。正如有人指出的,args是用于绑定(bind)方法参数,而不是注释。

关于java - 在带参数的注释之前未调用方面,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51513527/

相关文章:

java - JsonPath 忽略输出的调试日志

java - 在 Ubuntu 18.04 上安装 Tomcat 9.0.16

java - 更改了包名称,现在 AndroidManifest.xml 不起作用

java - 使用AspectJ的异步执行切面

java - Gradle + AspectJ找不到参数 “'的方法Aspectj()Aspectj'无法应用于 '(?, java.lang.String, ?, ?)'”

java - 为什么Maven中的Aspects无法应用?

java - GhostScript:gswin32c 挂起,但 gswin32 可以工作

java - Jena Sparql 仅返回实例的直接父类(super class)

java - 在 AspectJ 中捕获建议执行(通知建议)

Java - Spring AspectJ AfterThrowing