これは解決された古い問題のようですが、残念ながら私は良い参考文献を見つけることができませんでした。 私はJavaassistを使用するJavaアプリケーションを持っています。 Webstartアプリケーションにアップグレードするまでうまくいきました。 Javaassistは私にclassNotFoundExceptionを与えます。クラスは間違いなくクラスパスにあります。JavaassistとWebstart
私はこの関連記事を見つけましたhttps://community.jboss.org/message/302408これは一種のもので、私はそれを解読できませんでした。誰かが私にここで手をつけることはできますか?ここで
おかげ
は、コードスニペットです:
ctClasses = new HashMap<String, CtClass>();
classPool = ClassPool.getDefault();
try {
ctEntity = classPool.get("org.myclass");
} catch (NotFoundException e) {
logger.error("Could not find entity class, this should not happen");
throw new RuntimeException("Could not find Entity class",e);
}
スタックトレースでは何もありません。
java.lang.RuntimeException: Could not find Entity class
at ca.cbc.panacea.metadata.JavassistClassGeneratorImpl.<init>(JavassistClassGeneratorImpl.java:32)
at ca.cbc.panacea.metadata.ClassGeneratorFactory.getDefaultClassGenerator(ClassGeneratorFactory.java:12)
at ca.cbc.panacea.metadata.ClassCreator.<init>(ClassCreator.java:30)
at ca.cbc.panacea.Panacea.digestMappingFile(Panacea.java:75)
at ca.cbc.panacea.console.PanaceaConsole.validateMappingFile(PanaceaConsole.java:46)
at ca.cbc.panacea.console.PanaceaConsoleUI.actionPerformed(PanaceaConsoleUI.java:132)
at javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:2028)
at javax.swing.AbstractButton$Handler.actionPerformed(AbstractButton.java:2351)
at javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel.java:387)
at javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:242)
at javax.swing.plaf.basic.BasicButtonListener.mouseReleased(BasicButtonListener.java:236)
at java.awt.Component.processMouseEvent(Component.java:6373)
at javax.swing.JComponent.processMouseEvent(JComponent.java:3267)
at java.awt.Component.processEvent(Component.java:6138)
at java.awt.Container.processEvent(Container.java:2085)
at java.awt.Component.dispatchEventImpl(Component.java:4735)
at java.awt.Container.dispatchEventImpl(Container.java:2143)
at java.awt.Component.dispatchEvent(Component.java:4565)
at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4621)
at java.awt.LightweightDispatcher.processMouseEvent(Container.java:4282)
at java.awt.LightweightDispatcher.dispatchEvent(Container.java:4212)
at java.awt.Container.dispatchEventImpl(Container.java:2129)
at java.awt.Window.dispatchEventImpl(Window.java:2478)
at java.awt.Component.dispatchEvent(Component.java:4565)
at java.awt.EventQueue.dispatchEventImpl(EventQueue.java:679)
at java.awt.EventQueue.access$000(EventQueue.java:85)
at java.awt.EventQueue$1.run(EventQueue.java:638)
at java.awt.EventQueue$1.run(EventQueue.java:636)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.AccessControlContext$1.doIntersectionPrivilege(AccessControlContext.java:87)
at java.security.AccessControlContext$1.doIntersectionPrivilege(AccessControlContext.java:98)
at java.awt.EventQueue$2.run(EventQueue.java:652)
at java.awt.EventQueue$2.run(EventQueue.java:650)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.AccessControlContext$1.doIntersectionPrivilege(AccessControlContext.java:87)
at java.awt.EventQueue.dispatchEvent(EventQueue.java:649)
at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:296)
at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:211)
at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:201)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:196)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:188)
at java.awt.EventDispatchThread.run(EventDispatchThread.java:122)
Caused by: javassist.NotFoundException: ca.cbc.panacea.metadata.Entity
at javassist.ClassPool.get(ClassPool.java:436)
at ca.cbc.panacea.metadata.JavassistClassGeneratorImpl.<init> (JavassistClassGeneratorImpl.java:29)
問題は実際にはClassLoaderです。 JNLPはjavaコマンドラインとは異なるクラスローダーを使用します。問題は、JNLPクラスローダーをJavassistと調整する方法です。
私の推測では、Webstartアプリケーションでは標準Javaアプリケーションとは異なるクラスローダーが原因でエラーが発生していると思います。 Javassist ClassPoolを作成/取得するコードスニペットの投稿とエラーのスタックトレース(クラスルックアップが失敗したときにどのクラスローダーが使用されているかのヒントを与えるかもしれません)を提案してください。 – prunge