Я делаю первый простой RESTFul API для моего проекта и использую Maven.Фрист, я создал maven архетипа jersey-quickstart-webapp с API по умолчанию.Я добавил свои файлы, добавил зависимости.Однако, когда я использую URL-адрес API: localhost: 8080 / webapi / myresource -> у меня ошибка 500, вот она:
HTTP Status 500 - Внутренняя ошибка сервера
Отчет об исключении типа
Сообщение Servlet.init () для сервлета [веб-приложение Джерси] вызвало исключение
Описание Сервер обнаружил непредвиденное состояние, которое не позволило ему выполнить запрос.
Исключение
javax.servlet.ServletException: Servlet.init () для сервлета [Веб-приложение на Джерси] вызвало исключение org.apache.catalina.authenticator.AuthenticatorBase.invoke (AuthenticatorBase.java): 493) org.apache.catalina.valves.ErrorReportValve.invoke (ErrorReportValve.java:81) org.apache.catalina.valves.AbstractAccessLogValve.invoke (AbstractAccessLogValve.java:650) org.apache.catoyoteconnector(CoyoteAdapter.java:342) org.apache.coyote.http11.Http11Processor.service (Http11Processor.java:800) org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66) org.apache.coyote.AbstractProtocol $ ConnectionHandler.process (AbstractProtocol.java:806) org.apache.tomcat.util.net.NioEndpoint $ SocketProcessor.doRun (NioEndpoint.java:1498) org.apache.tomcat.util.net.SocketProcessorBase.run (SocketProcessorBase.java:49) java.util.concurrent.ThreadPoolExecutor.runWorker (неизвестный источник) java.util.concurrent.ThreadPoolExecutor $ Worker.run (неизвестный источник) org.util.threads.TaskThread $ WrappingRunnable.run (TaskThread.java:61) java.lang.Thread.run (неизвестный источник)
Основная причина
java.lang.NoSuchMethodError: org.glassfish.hk2.api.ServiceLocatorFactory.create (Ljava / lang / String; Lorg / glassfish / hk2 / api / ServiceLocator; Lorg / glassfish / hk2 / extension / ServiceLocatorGenerator; Lorg / glass / aph / hkServiceLocatorFactory $ CreatePolicy;) Lorg / GlassFish / hk2 / API / ServiceLocator;org.glassfish.jersey.inject.hk2.AbstractHk2InjectionManager.createLocator (AbstractHk2InjectionManager.java:114) org.glassfish.jersey.inject.hk2.AbstractHk2InjectionManager. (AbstractHk2InjectionManager.jseyI.j.jj.jj.jj.jj.jj.jj.jj.jj.jj.jj.jjjjjjg) .jt). (ImmediateHk2InjectionManager.java:62) org.glassfish.jersey.inject.hk2.Hk2InjectionManagerFactory $ Hk2InjectionManagerStrategy $ 1.createInjectionManager (Hk2InjectionManagerFactory.java:79.) org.glassfish.jersey.internal.inject.Injection.createInjectionManager (Injection.java:93) org.glassfish.jersey.server.ApplicationHandler. (ApplicationHandler.java:282) org.glassfish.jersey.servlet.WebComponent. (WebComponent.).java: 335) org.glassfish.jersey.servlet.ServletContainer.init (ServletContainer.java:178) org.glassfish.jersey.servlet.ServletContainer.init (ServletContainer.java:370) javax.servlet.GenericServlet.in.java: 158) org.apache.catalina.authenticator.AuthenticatorBase.invoke (AuthenticatorBase.java:493) org.apache.catalina.valves.ErrorReportValve.invoke (ErrorReportValve.java:81) org.apache.catValb.AveAveve.Lave.invoke (AbstractAccessLogValve.java:650) org.apache.catalina.connector.CoyoteAdapter.service (CoyoteAdapter.java:342) org.apache.coyote.http11.Http11Processor.service (Http11Processor.java:800 или org.co.co.g)AbstractProcessorLight.process (AbstractProcessorLight.java:66) org.apache.coyote.AbstractProtocol $ ConnectionHandler.process (AbstractProtocol.java:806) org.apache.tomcat.util.net.NioEndpoint $ SocketProcessor.doRun (NioEndpoint.java:1498org.apache.tomcat.util.net.SocketProcessorBase.run (SocketProcessorBase.java:49)java.util.concurrent.ThreadPoolExecutor.runWorker (неизвестный источник)java.lang.Thread.run (неизвестный источник)
Примечание. Полная трассировка стека основной причины доступна в журналах сервера.Apache Tomcat / 8.5.33
А вот так выглядит мой файл pom.xml: http://maven.apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>org.glassfish.jersey.archetypes</groupId>
<artifactId>ParkingSystem</artifactId>
<packaging>war</packaging>
<version>1.0-SNAPSHOT</version>
<name>ParkingSystem</name>
<build>
<finalName>ParkingSystem</finalName>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>2.5.1</version>
<inherited>true</inherited>
<configuration>
<source>1.7</source>
<target>1.7</target>
</configuration>
</plugin>
</plugins>
</build>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.glassfish.jersey</groupId>
<artifactId>jersey-bom</artifactId>
<version>${jersey.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<dependencies>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>3.0.1</version>
<type>jar</type>
</dependency>
<dependency>
<groupId>org.glassfish.hk2</groupId>
<artifactId>hk2-api</artifactId>
<version>2.5.0-b42</version>
</dependency>
<dependency>
<groupId>org.glassfish.jersey.containers</groupId>
<artifactId>jersey-container-servlet-core</artifactId>
<!-- use the following artifactId if you don't need servlet 2.x compatibility -->
<!-- artifactId>jersey-container-servlet</artifactId -->
</dependency>
<dependency>
<groupId>org.glassfish.jersey.inject</groupId>
<artifactId>jersey-hk2</artifactId>
</dependency>
<dependency>
<groupId>org.glassfish.jersey.media</groupId>
<artifactId>jersey-media-json-binding</artifactId>
</dependency>
</dependencies>
<properties>
<jersey.version>2.27</jersey.version>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
</project>
Я использую Netbeans и Tomcat.Я думал, что ошибка вызвана отсутствием зависимости hk2-api, но ничего не изменилось, когда я ее добавил.