Я работаю над проектом grails, и я поместил файл .jar в каталог lib проекта.
Я продолжаю получать исключение времени выполнения для ClassNotFoundException в одном из моих java-файлов, которые я использую в проекте grails.
У меня есть метод, определенный как таковой:
void printValues(org.docx4j.wml.ParaRPr rpr){
}
, и у меня есть раздел импорта, который выглядит как
import org.docx4j.openpackaging.exceptions.Docx4JException;
import org.docx4j.openpackaging.packages.WordprocessingMLPackage;
import org.docx4j.openpackaging.parts.WordprocessingML.MainDocumentPart;
import org.docx4j.wml.Body;
import org.docx4j.wml.Style;
Это то, что вызывает исключение.
Однако, если я изменю свой метод на
void printValues(org.docx4j.openpackaging.parts.WordprocessingML.MainDocumentPart rpr){
}
Я не получаю исключения времени выполнения.
Что здесь может происходить? Я убедился, что файл docx4j.jar содержит ParaRPr, и это так. Я подтвердил, что эти классы являются общедоступными, и это так. Кроме того, я пробовал разные классы из каталога org.docx4j.wml, и некоторые из них выдают мне исключение, а некоторые - нет. Как это вообще возможно?
Вот полная трассировка стека:
2010-09-15 12:37:00,198 [http-8080-1] ERROR errors.GrailsExceptionResolver - org.docx4j.wml.ParaRPr
java.lang.ClassNotFoundException: org.docx4j.wml.ParaRPr
at java.net.URLClassLoader$1.run(URLClassLoader.java:202)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
at java.lang.ClassLoader.loadClass(ClassLoader.java:307)
at java.lang.ClassLoader.loadClass(ClassLoader.java:248)
at java.lang.Class.getDeclaredMethods0(Native Method)
at java.lang.Class.privateGetDeclaredMethods(Class.java:2427)
at java.lang.Class.getDeclaredMethods(Class.java:1791)
at java.security.AccessController.doPrivileged(Native Method)
at org.codehaus.groovy.util.LazyReference.getLocked(LazyReference.java:46)
at org.codehaus.groovy.util.LazyReference.get(LazyReference.java:33)
at javatest.ResumeController$_closure4.doCall(ResumeController.groovy:47)
at javatest.ResumeController$_closure4.doCall(ResumeController.groovy)
at java.lang.Thread.run(Thread.java:619)
[groovyc] Compiling 1 source file to C:\dev\JavaTest\target\classes
Вот вывод jar -tf в файле jar - там показан класс ParaRPr
$ jar -tf docx4j-nightly-20100914.jar | grep Para
org/docx4j/dml/CTTextParagraph.class
org/docx4j/dml/CTTextParagraphProperties.class
org/docx4j/dml/diagram/CTParameter.class
org/docx4j/dml/diagram/STParameterId.class
org/docx4j/math/CTOMathPara.class
org/docx4j/math/CTOMathParaPr.class
org/docx4j/model/properties/paragraph/AbstractParagraphProperty.class
org/docx4j/wml/CTParaRPrOriginal.class
org/docx4j/wml/ParaRPr.class
org/docx4j/wml/ParaRPrChange.class
org/pptx4j/pml/CTTLBuildParagraph.class
org/pptx4j/pml/CTTLTimeNodeParallel.class
org/pptx4j/pml/STTLParaBuildType.class
org/xlsx4j/sml/CTParameter.class
org/xlsx4j/sml/CTParameters.class
org/xlsx4j/sml/STParameterType.class