ByteBuddy(九)—Around Advice 方法参数
Around Advice的Advice方法可以使用注解来绑定其参数。
当使用around advice时,这些注解用于访问函数代码的Java元素。
本章解释如何使用这些注解的示例代码。
这是PerfReturnInterceptor.java的代码,它使用绑定参数:
public class PerfReturnInterceptor {
public static Logger logger = Logger.getLogger(PerfReturnInterceptor.class.getName());
@RuntimeType
public static Object aroundReturn(
@Super Object zuper,
@SuperCall Callable<Object> instrumentedMethod,
@SuperMethod Method superMethod,
@This Object target,
@Origin Method method,
@AllArguments Object[] args,
@Argument(0) int p1,
@Argument(1) String p2,
@FieldValue("objectId") int data1,
@FieldValue("data") String data2) throws Throwable{
long startTime = System.currentTimeMillis();
logger.info("Methodstart:\n"
+ "@Super:" + zuper.getClass().getName() + "\n"
+ "@SuperMethod:" + superMethod.getName() + "\n"
+ "@This:" + target.getClass().getName() + "\n"
+ "@AllArgumentslength:" + args.length + "\n"
+ "@AllArguments[0]:" + ((int)args[0]) + "\n"
+ "@AllArguments[1]:" + ((String)args[1]) + "\n"
+ "@Argument(0):" + p1 + "\n"
+ "@Argument(1):" + p2 + "\n"
+ "@FieldValue('objectId'):" + data1 + "\n"
+ "@FieldValue('data'):" + data2 + "\n" );
Object result = instrumentedMethod.call();
logger.info("Method end: " + method.getName()+" execution time: " + (System.currentTimeMillis() - startTime));
return result;
}
}
aroundReturn方法是一个可以返回对象的around Advice。
该方法使用这些注解,这些注解包含在net.bytebuddy.implementation.bind.annotation
中
- @Super
- @SuperMethod
- @This
- @AllArguments
- @Argument
- @FieldValue
1、@Super注解提供由ByteBuddy生成的代理类的实例
参数:@Super Obiect zuper
System.out.println(zuper.getclass().getName();
在屏幕上打印此字符串值:
com.wpixel.bytebuddy.chapter1.DataProducer$auxiliary.mxySvqOW
2、@SuperMethod注解提供了java.lang.reflect的实例
参数:@SuperMethod Method SuperMethod
System.out.println(superMethod.getName());
在屏幕上打印此字符串值:
createData$original
这里的示例提供了一个简单的方法名。
ByteBuddy实际上可以使用随机字符创建方法名,例如,createData$original$AOgPLhp9$accessor$sMMz5BQl
3、@This注释提供了功能代码的实例。
参数:@This Obiect target
System.out.println(target.getClass().getName());
在屏幕上打印此字符串值:
com.wpixel.bytebuddy.chapter1.DataProducer
4、@AllArguments注释以对象数组格式提供createData方法的所有参数的值。
例如,Main1.java调用:
new DataProducer.create(1, "base64");
参数: @AllArguments Object[] args
System.out.println(args[0] + " " + args[1]);
在屏幕上打印此字符串值:
1 base64
5、@Argument注释提供createData方法的参数值。此注释接受一个表示方法参数的索引号的整数参数。
例如,Main1.java调用:
new DataProducer.create(1, "base64");
参数:
@Argument(0) int p1
@Argument(1) String p2
System.out.println(p1 + " " + p2);
在屏幕上打印此字符串值:
1 base64
索引0表示第一个参数,索引1 表示第二个参数,依此类推。
Around Advice不能更改函数方法的参数值。
6、@FieldValue注释提供函数代码的实例变量的值。
此注解接受表示实例变量名称的一个参数。
例如,DataProducer.java声明了这两个实例变量:
public int objectId = -1;
private String data = "producer data";
参数:
@FieldValue("objectId") int data1
@FieldValue("data") String data2
System.out.println(data1 + " " + data2);
在屏幕上打印此字符串值:
-1 producer data
与 onMethodEnter/Exit
Advice中使用的@FieldValue
不同,Around
Advice的@FildValue
注解不能更改
函数代码的实例变量的值。
结论
本章解释了如何使用around advice的参数,包括以下注释:
- @Super
- @SuperMethod
- @This
- @AllArguments
- @Argument
- @FieldValue
bytebuddy书籍《Java Interceptor Development with ByteBuddy: Fundamental》
喜欢就点个👍吧