首页 > 解决方案 > 如何使用 Instrumentation 的 Java API 捕获 HTTP 请求和响应?

问题描述

我正在编写一个-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;
    });
}

标签: javainstrumentationjavaagentscglibjava-assist

解决方案


推荐阅读