1

Weblogic 10.3 で実行されている Web アプリケーションで、非常に奇妙なクラスが見つからないという問題が発生しました。このコードでは、非常に標準的な 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 の一部であり、間違いなくクラスパスにあります。これは、次の 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

では、一体何がここで問題になるのでしょうか?

4

1 に答える 1

3

NoClassDefFoundError は、必ずしもクラスが見つからなかったことを意味するわけではありません。クラスの正しいバージョンがロードされていないことを意味します。

クラスの複数のバージョンがロードされている可能性があります。競合の原因があるかどうかを確認できますか?たとえば、いくつかのクラスが weblogic.jar にもバンドルされています。

このパッケージ org/apache/xalan/internal/xsltc/runtime/BasisLibrary または BasisLibrary クラス自体を確認してください - 存在しますか?

または、rt.jar をクラスパスの最初の jar として配置してみてください

于 2010-03-11T12:12:43.793 に答える