Java 带有字节伙伴的简单After和Before方法拦截器

Java 带有字节伙伴的简单After和Before方法拦截器,java,bytecode,byte-buddy,Java,Bytecode,Byte Buddy,在写这篇文章的时候,所有的东西都被解释了,但是一个简单的前后方法拦截器并不存在,正如我在下面解释的,我是否遗漏了什么或者教程很复杂。(参见LoggerInterceptor示例给出方法但不给出对象,ChangingLoggerInterceptor示例给出对象但不调用方法) 我想要实现的是在对象的setter方法执行之后调用该对象的方法。如何编写拦截器并在Java6中使用它 public class DirtyClass{ private String _sField; private boo

在写这篇文章的时候,所有的东西都被解释了,但是一个简单的前后方法拦截器并不存在,正如我在下面解释的,我是否遗漏了什么或者教程很复杂。(参见LoggerInterceptor示例给出方法但不给出对象,ChangingLoggerInterceptor示例给出对象但不调用方法)

我想要实现的是在对象的setter方法执行之后调用该对象的方法。如何编写拦截器并在Java6中使用它

public class DirtyClass{

private String _sField;
private boolean _bDirty;

public void setField(String sField) {
    _sField = sField;
    //setDirty(true); to be appended after proxying
}
public String getField() {
    return _sField;
}
public void setDirty(boolean bDirty){
    _bDirty = bDirty;
}
public boolean isDirty(){
    return _bDirty;
}
}

DirtyClass d = new ByteBuddy().subclass(DirtyClass.class)...???

d.setField("dirty now");
System.out.println(d.isDirty()); //Expecting true

即使没有方法委派,您也可以实现这样的机制,如下所示:

DirtyClass d = new ByteBuddy()
  .subclass(DirtyClass.class)
  .method(isSetter().and(not(named("setDirty"))))
  .intercept(SuperMethodCall.INSTANCE.andThen(
      MethodCall.invoke(DirtyClass.class.getMethod("setDirty", boolean.class))
                .with(true)
  )).make()
  .load(DirtyClass.class.getClassLoader())
  .getLoaded()
  .newInstance();
这样,每个setter都会被重写,首先调用其super方法,然后以
true
作为参数调用
setDirty
方法。不过,注释中的链接示例也应该起作用

拦截器可以如下所示(假定实现了一些接口
可指示的
):


这假设插入指令的超类实现了
Dirtiable
接口,该接口可以使用
.implement(Dirtiable.class)
实现,其中可以使用
FieldAccessor
实现方法来设置字段。

类似的内容?尝试将其用作setter拦截器,但是获取异常:java.lang.IllegalArgumentException:No[…]都不允许来自public void的委托…好的,这很好。由于我计划调用不同的方法并进行其他setter筛选,您能否分享一个使用拦截器类的示例?我自己无法编写拦截器类和拦截器方法,也无法找到完整参数列表的文档。感谢您提供示例。第二个示例不适用于我的情况,如果是这样,我将使用java的反射代理。虽然我不喜欢第一个例子,但似乎第一个例子就是要走的路。
public class Interceptor {
  public static void getter(@SuperCall Runnable zuper, @This Dirtiable self) {
    zuper.run();
    self.setDirty(true);
  }
}