我正在编写一个-javaagent
使用 Java 的 Instrumentation API(例如 javassist
/ )来捕获 HTTP 请求和响应asm
。我可以在方法周围插入代码,但是如果该方法即将进行 HTTP 调用并捕获 HTTP 请求详细信息、响应代码,我该如何捕获?
public static void premain(
String agentArgs,
Instrumentation inst
) throws IOException {
inst.addTransformer((classLoader, className, classBeingRedefined, protectionDomain, classfileBuffer) -> {
try {
ClassPool cp = ClassPool.getDefault();
CtClass cc = cp.get("other.Stuff");
CtMethod m = cc.getDeclaredMethod("run");
m.addLocalVariable("elapsedTime", CtClass.longType);
m.insertBefore("elapsedTime = System.currentTimeMillis();");
m.insertAfter(
"{elapsedTime = System.currentTimeMillis() - elapsedTime;"
+ "System.out.println(\"Method Executed in ms: \" + elapsedTime);}");
byte[] byteCode = cc.toBytecode();
cc.detach();
return byteCode;
} catch (Exception ex) {
ex.printStackTrace();
}
return null;
});
}