Создание простого API Restful в Java - PullRequest
0 голосов
/ 24 января 2019

Я пытаюсь создать простой API-интерфейс Restful hello через intellij.Я создал проект maven с maven-archetype-quickstart, а затем в pom.xml я добавил

<dependency>
  <groupId>org.jboss.resteasy</groupId>
  <artifactId>resteasy-jaxrs</artifactId>
  <version>2.3.7.Final</version>
  <scope>provided</scope>
</dependency>

Затем в src-> main-> java-> webservice у меня есть два файла: App.java

    package webservice;

/**
 * Hello world!
 *
 */
public class App 
{
    public static void main( String[] args )
    {
        System.out.println( "Hello World!" );
    }
}

и BookRestService.java

package webservice;

import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;

@Path("/book")
public class BookRestService {
    @GET
    @Produces("text/plain")
    public String getBookTitle() {
        return "H2G2";
    }
}

Я использую jBoss-6.4.Кажется, Jboss начинает выдавать мне следующее сообщение:

15:08:01,550 INFO  [org.jboss.ws.common.management] (MSC service thread 1-2) JBWS022052: Starting JBoss Web Services - Stack CXF Server 4.3.4.Final-redhat-1
15:08:01,824 INFO  [org.jboss.as.remoting] (MSC service thread 1-1) JBAS017100: Listening on 127.0.0.1:4447
15:08:01,824 INFO  [org.jboss.as.remoting] (MSC service thread 1-7) JBAS017100: Listening on 127.0.0.1:9999
15:08:01,827 INFO  [org.jboss.as.server.deployment.scanner] (MSC service thread 1-3) JBAS015012: Started FileSystemDeploymentService for directory /home/symeon/myprojects/applicationserver/jboss-eap-6.4-clean/standalone/deployments
15:08:02,113 INFO  [org.jboss.as] (Controller Boot Thread) JBAS015961: Http management interface listening on http://127.0.0.1:9990/management
15:08:02,114 INFO  [org.jboss.as] (Controller Boot Thread) JBAS015951: Admin console listening on http://127.0.0.1:9990
15:08:02,115 INFO  [org.jboss.as] (Controller Boot Thread) JBAS015874: JBoss EAP 6.4.0.GA (AS 7.5.0.Final-redhat-21) started in 5345ms - Started 153 of 191 services (57 services are lazy, passive or on-demand)
Connected to server
[2019-01-24 03:08:02,544] Artifact webservice: Artifact is being deployed, please wait...
15:08:02,721 INFO  [org.jboss.as.server.deployment] (MSC service thread 1-6) JBAS015876: Starting deployment of "webservice" (runtime-name: "webservice.war")
15:08:03,236 INFO  [org.jboss.web] (ServerService Thread Pool -- 7) JBAS018210: Register web context: /webservice
15:08:03,400 INFO  [org.jboss.as.server] (management-handler-thread - 2) JBAS015859: Deployed "webservice" (runtime-name : "webservice.war")
[2019-01-24 03:08:03,428] Artifact webservice: Artifact is deployed successfully
[2019-01-24 03:08:03,428] Artifact webservice: Deploy took 884 milliseconds

Я ожидаю, когда открою браузер и напишу http://localhost:8080/book, чтобы увидеть H2G2 в качестве ответа.Я также попытался http://localhost:8080/webservice/book, поскольку в нем упоминается, что веб-контекст был зарегистрирован в / webservice, но снова безуспешно.Я получаю ошибку 404 Not Found.Что я делаю не так?

Ответы [ 3 ]

0 голосов
/ 24 января 2019

По умолчанию resteasy не сканирует весь ваш проект на предмет класса обслуживания.Вы должны сказать resteasy, чтобы сканировать его.Используйте приведенный ниже код в web.xml для включения сканирования.

<context-param>
    <param-name>resteasy.scan</param-name>
    <param-value>true</param-value>
</context-param>

Источник

0 голосов
/ 24 января 2019

В вашем App.java вам нужно определить ApplicationPath. Что-то вроде ниже.

import java.util.HashSet;
import java.util.Set;

import javax.ws.rs.ApplicationPath;
import javax.ws.rs.core.Application;

@ApplicationPath("/restRoot")
public class App extends Application {

    @Override
    public Set<Class<?>> getClasses() {
        HashSet<Class<?>> classes = new HashSet<Class<?>>();
        classes.add(BookRestService.class);

        return classes;
    }
}

После этого ваш REST URL станет

http://localhost:8080/webservice/restRoot/book
0 голосов
/ 24 января 2019
Register web context: /webservice

означает, что все пути, которые вы кодировали, должны быть после / webservice.Поэтому вместо http://localhost:8080/book вы должны использовать http://localhost:8080/webservice/book

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