1

我正在尝试创建一个将采用一系列方法的日志记录系统。我正在拦截的一些方法有 0 个参数,其他的有很多。我的问题是:我可以使用 ByteBuddy 创建一个可以捕获@Advice.OnMethodEnter参数的泛型吗?@Advice.AllArguments

该方法如下所示:

@Advice.OnMethodEnter
public static void intercept(@Port int port, 
                             @Host String host, 
                             @Advice.Origin("#t:#m") String signature, 
                             @Advice.AllArguments Object[] arguments) 
{
    AgentHelper.log(host, port, signature, Arrays.toString(arguments));
}

当注释@Advice.AllArguments丢失时一切正常,但是我一放上它,所有没有参数的方法都被忽略了。

我还尝试使用以下方法查看是否存在显式错误:

new AgentBuilder.Default()
    ...
    .with(AgentBuilder.Listener.StreamWriting.toSystemOut().withErrorsOnly())
    .with(AgentBuilder.InstallationListener.StreamWriting.toSystemOut())
    ...

但这没有显示任何错误。我是否必须逐个创建拦截器,或者有没有办法以我不理解的方式获取这种行为?

4

1 回答 1

3

是的,这应该没有问题:

public class Example {
  public static void main(String[] args) {
    new AgentBuilder.Default()
      .disableClassFormatChanges()
       .with(AgentBuilder.RedefinitionStrategy.RETRANSFORMATION)
       .type(is(Target.class))
       .transform((builder, typeDescription, classLoader, module) -> 
               builder.visit(Advice.to(Example.class).on(isMethod())))
       .installOn(ByteBuddyAgent.install());

    new Target().method();
  }

  @Advice.OnMethodEnter
  public static void intercept(@Advice.AllArguments Object[] arguments) {
    System.out.println("Intercepted: " + Arrays.asList(arguments));
  }

  public static class Target {
    public void method() { }
  }
}

这将在调用时打印一个空列表。

于 2020-12-03T22:49:07.923 回答