2

我在使用 Reflections 0.9.9-RC1 jar 在 Weblogic 10.3.5 上部署 EAR 应用程序时遇到问题。

使用默认类加载器(weblogic.utils.classloaders.ChangeAwareClassLoader@396e8d0 finder: weblogic.utils.classloaders.CodeGenClassFinder@5bcfadd)我得到这个错误:

ExecuteThread: 2 for queue: weblogic.kernel.Default (self-tuning)] - could not create Dir using jarFile from url file:/D:/Servers/Oracle10.3.5/patch_wls1035/profiles/default/sys_manifest_classpath/weblogic_patch.jar. skipping.
   java.lang.NullPointerException: null
   at java.util.zip.ZipFile.<init>(ZipFile.java:108) ~[na:1.6.0_24]
   at java.util.jar.JarFile.<init>(JarFile.java:135) ~[na:1.6.0_24]
   at java.util.jar.JarFile.<init>(JarFile.java:99) ~[na:1.6.0_24]
   at org.reflections.vfs.Vfs$DefaultUrlTypes$1.createDir(Vfs.java:207) ~[reflections-0.9.9-RC1.jar:na]
   at org.reflections.vfs.Vfs.fromURL(Vfs.java:99) [reflections-0.9.9-RC1.jar:na]
   at org.reflections.vfs.Vfs.fromURL(Vfs.java:91) [reflections-0.9.9-RC1.jar:na]
   at org.reflections.Reflections.scan(Reflections.java:231) [reflections-0.9.9-RC1.jar:na]
   at org.reflections.Reflections.scan(Reflections.java:204) [reflections-0.9.9-RC1.jar:na]
   at org.reflections.Reflections.<init>(Reflections.java:129) [reflections-0.9.9-RC1.jar:na]

ExecuteThread: 2 for queue: weblogic.kernel.Default (self-tuning)] - could not create Vfs.Dir from url. ignoring the exception and continuing
   org.reflections.ReflectionsException: Could not open url connection
   at org.reflections.vfs.JarInputDir$1$1.<init>(JarInputDir.java:36) ~[reflections-0.9.9-RC1.jar:na]
   at org.reflections.vfs.JarInputDir$1.iterator(JarInputDir.java:32) ~[reflections-0.9.9-RC1.jar:na]
   at org.reflections.Reflections.scan(Reflections.java:231) ~[reflections-0.9.9-RC1.jar:na]
   at org.reflections.Reflections.scan(Reflections.java:204) ~[reflections-0.9.9-RC1.jar:na]
   at org.reflections.Reflections.<init>(Reflections.java:129) ~[reflections-0.9.9-RC1.jar:na]

这是代码部分:

List<ClassLoader> classLoadersList = new LinkedList<ClassLoader>();
classLoadersList.add(Thread.currentThread().getContextClassLoader());

Reflections ref = new Reflections(new ConfigurationBuilder()
                .setScanners(new SubTypesScanner(false /* don't exclude Object.class */), new ResourcesScanner())
                .setUrls(ClasspathHelper.forClassLoader(classLoadersList.toArray(new ClassLoader[0])))
                .filterInputsBy(new FilterBuilder().include(FilterBuilder.prefix(p))));

我也试图从中获取类加载器:

//classLoadersList.add(ClasspathHelper.contextClassLoader());
//classLoadersList.add(this.getClass().getClassLoader());
//classLoadersList.add(ClasspathHelper.staticClassLoader());

但它在所有这些中返回相同的类加载器。

在 localhost 中,如果我将 jar 放在指定的目录中,它显然可以工作,但我在将要部署它的服务器中没有该选项。

有什么建议么?

4

2 回答 2

0

你的代码没问题,我也有同样的问题。此问题与处理一个从不抛出的内部异常有关...

我已向 Reflections 提交了一项可能的纠正措施:

https://groups.google.com/forum/#!topic/google-code-reflections/EtwuzC_Eesc

于 2014-05-07T13:03:52.153 回答
0

确保从 ClasspathHelper.forXXX 方法之一获得正确的 url,并且这些 url 存在且可访问。

您可能不想扫描 weblogic_patch.jar,而是扫描应用程序的 jar。

于 2014-04-29T09:27:30.970 回答