java.lang.ClassNotFoundException: javax.xml.rpc.Stub - после развертывания на tomcat

Stacktrace:] with root cause
java.lang.ClassNotFoundException: javax.xml.rpc.Stub
    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:306)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:247)
    at java.lang.ClassLoader.defineClass1(Native Method)
    at java.lang.ClassLoader.defineClassCond(ClassLoader.java:631)
    at java.lang.ClassLoader.defineClass(ClassLoader.java:615)
    at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:141)
    at java.net.URLClassLoader.defineClass(URLClassLoader.java:283)
    at java.net.URLClassLoader.access$000(URLClassLoader.java:58)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:197)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:306)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:247)
    at java.lang.Class.forName0(Native Method)
    at java.lang.Class.forName(Class.java:247)
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1688)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:295)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:247)
    at com.agile.api.pc.EJBLookup.createFileSession(EJBLookup.java:462)
    at com.agile.api.pc.attachment.IFSInputStream.createFileSession(IFSInputStream.java:132)
    at com.agile.api.pc.attachment.IFSInputStream.<init>(IFSInputStream.java:37)
    at com.agile.api.pc.RowAttachment$GetFileAction.doSdkAction(RowAttachment.java:556)
    at com.agile.api.common.SDKAction.run(SDKAction.java:23)
    at weblogic.security.acl.internal.AuthenticatedSubject.doAs(AuthenticatedSubject.java:363)
    at weblogic.security.service.SecurityManager.runAs(SecurityManager.java:146)
    at weblogic.security.Security.runAs(Security.java:61)
    at com.agile.api.common.WebLogicAuthenticator.doAs(WebLogicAuthenticator.java:111)
    at com.agile.api.common.Security.doAs(Security.java:54)
    at com.agile.api.common.Security.doAs(Security.java:109)
    at com.agile.api.pc.RowAttachment.getFile(RowAttachment.java:343)
    at gt.ext.agile.test.AdvancedQuery.downloadAttach(AdvancedQuery.java:232)
    at org.apache.jsp.OrderAttach_jsp._jspService(OrderAttach_jsp.java:176)
    at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:722)
    at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:432)
    at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:390)
    at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:334)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:722)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:224)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:169)
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:168)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:98)
    at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:927)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407)
    at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:987)
    at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:579)
    at org.apache.tomcat.util.net.AprEndpoint$SocketProcessor.run(AprEndpoint.java:1805)
    at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
    at java.lang.Thread.run(Thread.java:662)

Я получаю эту ошибку. Как я могу избежать этого исключения? У меня есть все банки под /WEB-INF/lib папку, но все же я получаю это исключение.

Когда я запускаю проект из Eclipse, он работает нормально, но после развертывания его на Tomcat из Agile PLM он дает мне указанное выше исключение.

2 ответа

Если вы используете плагин WTP (Web Tools Platform) Eclipse, вам не нужно помещать файлы jar в папку /lib. Вам нужно добавить нужную библиотеку в сборку развертывания [Свойства проекта (Alt+Enter) -> Сборка развертывания] после того, как нужный jar помещен в список, Eclipse поместит необходимые jar в саму папку /lib.

Проверьте, есть ли у вас конфликтующий файл JAR, или проверьте, что класс javax.xml.rpc.Stub существует в файлах JAR в каталоге lib.

Другие вопросы по тегам