XSLT-передача завершается неудачно, потому что Weblogic не может найти класс, расположенный в rt.jar - PullRequest
1 голос
/ 11 марта 2010

Мы столкнулись с очень странной проблемой не найденного класса в нашем веб-приложении, работающем на Weblogic 10.3. В нашем коде мы делаем довольно стандартное XSLT-преобразование.

UtilRequestManagerBean.java:

TransformerFactory tFactory = TransformerFactory.newInstance();
Transformer transformer = tFactory.newTransformer(new StreamSource(new StringReader(xslBuffer.toString())));            
transformer.transform(new StreamSource(new StringReader(sourceBuffer.toString())), new StreamResult(sw));

В нашей производственной среде происходит сбой (Solaris 10, если это имеет значение) и выдается ошибка java.lang.NoClassDefFoundError:

<Mar 11, 2010 1:44:08 PM EET> <Info> <EJB> <BEA-010227> <EJB Exception occurred during invocation from home or business: com.company.basicservice.ejb.util.UtilRequestManagerBean_temuyq_HomeImpl@1737be7 threw exception: java.lang.NoClassDefFoundError: Could not initialize class com.sun.org.apache.xalan.internal.xsltc.runtime.BasisLibrary>

Этот класс является частью rt.jar и определенно находится в classpath. Это подтверждается следующим фрагментом журнала Weblogic:

sun.boot.class.path = /opt/jdk1.6.0_12/jre/lib/resources.jar:/opt/jdk1.6.0_12/jre/lib/rt.jar:/opt/jdk1.6.0_12/jre/lib/sunrsasign.jar:/opt/jdk1.6.0_12/jre/lib/jsse.jar:/opt/jdk1.6.0_12/jre/lib/jce.jar:/opt/jdk1.6.0_12/jre/lib/charsets.jar:/opt/jdk1.6.0_12/jre/classes

И, наконец, перечисление содержимого файла rt.jar показывает, что класс существует:

jar tvf /opt/jdk1.6.0_12/jre/lib/rt.jar | grep BasisLibrary.class
24787 Sat Jan 17 02:25:58 EET 2009 com/sun/org/apache/xalan/internal/xsltc/runtime/BasisLibrary.class

Итак, с чем здесь может быть проблема?

1 Ответ

3 голосов
/ 11 марта 2010

NoClassDefFoundError не обязательно означает, что класс не найден - это означает, что правильная версия класса не была загружена.

Скорее всего, загружается несколько версий класса. Можете ли вы проверить, есть ли источник конфликта - например, некоторые классы также включены в weblogic.jar.

Проверьте наличие этого пакета org / apache / xalan / internal / xsltc / runtime / BasisLibrary или самого класса BasisLibrary - присутствует ли он?

Или попробуйте поставить rt.jar в качестве первого jar-файла в classpath

...