5
public byte[] transform(ClassLoader loader, String className, Class<?> clazz,
            ProtectionDomain domain, byte[] bytes)
    throws IllegalClassFormatException {
        return inspectClass(className, clazz, bytes);
}

private byte[] inspectClass(String name, Class<?> clazz, byte[] b) {
        System.out.println("here"); //OK I see this print
        ClassPool pool = ClassPool.getDefault();
        System.out.println("inclass"); //can't see it !!
}

会发生什么ClassPool.getDefault();

4

1 回答 1

6

我遇到了同样的问题,发现 ClassPool.getDefault 不是抛出异常,而是 Throwable。事实上,它正在抛出 java.lang.NoClassDefFoundError。在我的清单中,我有:

Premain-Class: timing.TimingTransform
Boot-Class-Path: lib/javassist.jar

您可能只需要将 Boot-Class-Path 指向 javassist.jar 文件。在我的例子中,使用上面的 Boot-Class-Path,我需要一个包含 javassist.jar 的 lib 目录。

我最初犯的错误是将 javassist.jar 放入代理 jar 文件中(以下内容不正确,仅用于演示目的):

     0 Mon Oct 24 16:58:14 MST 2011 META-INF/
   146 Mon Oct 24 16:58:14 MST 2011 META-INF/MANIFEST.MF
     0 Thu Oct 20 14:58:06 MST 2011 timing/
  2482 Mon Oct 24 16:58:06 MST 2011 timing/TimingStats.class
  8360 Mon Oct 24 16:58:06 MST 2011 timing/TimingTransform.class
     0 Tue Oct 18 17:28:24 MST 2011 lib/
645252 Fri Jul 08 18:24:58 MST 2011 lib/javassist.jar

我没有将 javassist.jar 放在代理 jar 文件中,而是将其放在程序可访问的外部目录中。更改后,它运行良好。

于 2011-10-25T00:25:20.030 回答