0

我有一个引用 2 个签名 jar 的小程序:

  • 我的applet.jar
  • jackson-all-1.9.9.jar

第二次启动小程序时(第一次没有错误),我得到这个:

Exception in thread "thread applet-main.MyApplet-1"
java.lang.ExceptionInInitializerError
              at org.codehaus.jackson.map.deser.StdDeserializerProvider.<init>(StdDeserializerProvider.java:81)
              at org.codehaus.jackson.map.ObjectMapper.<init>(ObjectMapper.java:398)
              at org.codehaus.jackson.map.ObjectMapper.<init>(ObjectMapper.java:358)
              at org.codehaus.jackson.map.ObjectMapper.<init>(ObjectMapper.java:328)
              at net.Remote.<init>(Remote.java:50)
              at main.Env.init(Env.java:44)
              at main.MyApplet.init(MyApplet.java:25)
              at sun.plugin2.applet.Plugin2Manager$AppletExecutionRunnable.run(Unknown Source)
              at java.lang.Thread.run(Unknown Source) 
Caused by: java.lang.SecurityException: Prohibited package name: java.util
              at java.lang.ClassLoader.preDefineClass(Unknown Source)
              at java.lang.ClassLoader.defineClassCond(Unknown Source)
              at java.lang.ClassLoader.defineClass(Unknown Source)
              at java.security.SecureClassLoader.defineClass(Unknown Source)
              at sun.plugin2.applet.Applet2ClassLoader.findClass(Unknown Source)
              at sun.plugin2.applet.Plugin2ClassLoader.loadClass0(Unknown Source)
              at sun.plugin2.applet.Plugin2ClassLoader.loadClass(Unknown Source)
              at sun.plugin2.applet.Plugin2ClassLoader.loadClass(Unknown Source)
              at java.lang.ClassLoader.loadClass(Unknown Source)
              at java.lang.Class.forName0(Native Method)
              at java.lang.Class.forName(Unknown Source)
              at org.codehaus.jackson.map.deser.BasicDeserializerFactory.<clinit>(BasicDeserializerFactory.java:74)
              ... 9 more

有问题的行是以下 try-catch 块中的第一行:

try {
    Class<?> key = Class.forName("java.util.ConcurrentNavigableMap");
    Class<?> value = Class.forName("java.util.ConcurrentSkipListMap");
    @SuppressWarnings("unchecked")
        Class<? extends Map<?,?>> mapValue = (Class<? extends Map<?,?>>) value;
    _mapFallbacks.put(key.getName(), mapValue);
} catch (ClassNotFoundException cnfe) { // occurs on 1.5
}

有几件事我不明白:

  • 为什么我的 Java7 JVM 没有将其从运行时库中取出?反而
  • 为什么它会尝试/java/util/ConcurrentNavigableMap.class从我的服务器下载,这显然失败了404
  • 既然失败了,为什么它会尝试连续快速重新下载myapplet.jar25次,每次都成功(200),每次都返回相同的jar文件?

更新我不确定 25 次重试是否是由试图加载类的类加载器引起的,可能是其他一些代码试图加载资源(这仍然很奇怪,但与CurrentNavigableMap问题无关),所以我'将从我的问题中排除。

注意我猜它不会尝试重新下载jackson jar文件,因为该文件已在cache_archive属性中列出。

4

1 回答 1

2

这是?

错误的:

Class.forName("java.util.ConcurrentNavigableMap");

正确:http:
//java.sun.com/javase/ja/6/docs/ja/api/java/util/concurrent/package-tree.html

Class.forName("java.util.concurrent.ConcurrentNavigableMap");
于 2012-09-10T13:07:45.293 回答