ClassNotFoundException: javax.jws.WebService - PullRequest
0 голосов
/ 29 марта 2020

Я пытаюсь развернуть простой сервлет java на Tomcat, который использует веб-сервис, который развернут на том же Tomcat на localhost. Я работаю с проектом Maven в Netbeans.

Сервлет импортирует следующие классы:

import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.xml.ws.WebServiceRef;

Я могу развернуть сгенерированный файл войны в Tomcat, но мне не удается запустите приложение со следующими ошибками в catalina.out:

    28-Mar-2020 20:57:12.769 SEVERE [http-nio-8080-exec-93] org.apache.catalina.startup.HostConfig.deployWAR Error deploying web application archive [/opt/tomcat/apache-tomcat-9.0.31/webapps/CalculatorWebServiceClient.war]
                        java.lang.IllegalStateException: Error starting child
                                at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:720)
                                at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:690)
                                at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:705)
                                at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:978)
                                at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:493)
                                at org.apache.catalina.startup.HostConfig.check(HostConfig.java:1642)
                                at jdk.internal.reflect.GeneratedMethodAccessor66.invoke(Unknown Source)
                                at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
                                at java.base/java.lang.reflect.Method.invoke(Method.java:566)
                                at org.apache.tomcat.util.modeler.BaseModelMBean.invoke(BaseModelMBean.java:289)
                                at java.management/com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.invoke(DefaultMBeanServerInterceptor.java:809)
                                at java.management/com.sun.jmx.mbeanserver.JmxMBeanServer.invoke(JmxMBeanServer.java:801)
                                at org.apache.catalina.manager.ManagerServlet.check(ManagerServlet.java:1590)
                                at org.apache.catalina.manager.HTMLManagerServlet.upload(HTMLManagerServlet.java:294)
                                at org.apache.catalina.manager.HTMLManagerServlet.doPost(HTMLManagerServlet.java:212)
                                at javax.servlet.http.HttpServlet.service(HttpServlet.java:660)
                                at javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
                ...
                  Caused by: org.apache.catalina.LifecycleException: Failed to start component [StandardEngine[Catalina].StandardHost[localhost].StandardContext[/CalculatorWebServiceClient]]
                                at org.apache.catalina.util.LifecycleBase.handleSubClassException(LifecycleBase.java:440)
                                at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:198)
                                at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:717)
                                ... 43 more
                        Caused by: java.lang.TypeNotPresentException: Type javax.jws.WebService not present
                                at java.base/sun.reflect.annotation.TypeNotPresentExceptionProxy.generateException(TypeNotPresentExceptionProxy.java:46)
                                at java.base/sun.reflect.annotation.AnnotationInvocationHandler.invoke(AnnotationInvocationHandler.java:86)
                                at com.sun.proxy.$Proxy2.value(Unknown Source)
                                at org.apache.catalina.startup.ContextConfig.processServletContainerInitializers(ContextConfig.java:1699)
                                at org.apache.catalina.startup.ContextConfig.webConfig(ContextConfig.java:1137)
                                at org.apache.catalina.startup.ContextConfig.configureStart(ContextConfig.java:774)
                                at org.apache.catalina.startup.ContextConfig.lifecycleEvent(ContextConfig.java:301)
                                at org.apache.catalina.util.LifecycleBase.fireLifecycleEvent(LifecycleBase.java:123)
                                at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5051)
                                at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183)
                                ... 44 more
                        Caused by: java.lang.ClassNotFoundException: javax.jws.WebService
                                at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1365)
                                at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1188)
                                at java.base/java.lang.Class.forName0(Native Method)
                                at java.base/java.lang.Class.forName(Class.java:398)
                                at java.base/sun.reflect.generics.factory.CoreReflectionFactory.makeNamedType(CoreReflectionFactory.java:114)

Я заметил ClassNotFoundException: javax.jws.WebService в файле журнала и отредактировал pom. xml включаемый файл:

javax.xml.ws.jaxws-api.2.3.1, а также его зависимости от компиляции согласно [https://mvnrepository.com/artifact/javax.xml.ws/jaxws-api/2.3.1/] [1] :

javax.annotation.javax.annotation-api.1.3.2
javax.xml.bind.jaxb-api.2.3.1
javax.xml.soap.javax.xml.soap-api.1.4.0

При проверке каталога проекта Я вижу, что соответствующие библиотеки присутствуют в каталоге WEB-INF / lib.

Даже после этого я получаю одно и то же сообщение об ошибке и не могу запустить приложение. Может кто-нибудь сказать мне, что мне здесь не хватает?

С уважением, Михал

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...