web-dev-qa-db-ja.com

ジャージーまたはresteasyの埋め込み桟橋

JAX-RS(resteasyまたはjersey)を備えた組み込み桟橋を使用してRESTfulサービスを作成したいと思います。 Maven/Eclipseセットアップで作成しようとしています。フォローしようとすると http://wikis.Sun.com/pages/viewpage.action?pageId=21725365 リンクServletHolder sh = new ServletHolder(ServletContainer.class);からエラーを解決できません

public class Main {

    @Path("/")
    public static class TestResource {

        @GET
        public String get() {
            return "GET";
        }
    }

    /**
     * @param args the command line arguments
     */
    public static void main(String[] args) throws Exception {
        ServletHolder sh = new ServletHolder(ServletContainer.class);

        /*
         * For 0.8 and later the "com.Sun.ws.rest" namespace has been renamed to
         * "com.Sun.jersey". For 0.7 or early use the commented out code instead
         */
        // sh.setInitParameter("com.Sun.ws.rest.config.property.resourceConfigClass",
        // "com.Sun.ws.rest.api.core.PackagesResourceConfig");
        // sh.setInitParameter("com.Sun.ws.rest.config.property.packages",
        // "jetty");
        sh.setInitParameter("com.Sun.jersey.config.property.resourceConfigClass",
            "com.Sun.jersey.api.core.PackagesResourceConfig");
        sh.setInitParameter("com.Sun.jersey.config.property.packages",
            "edu.mit.senseable.livesingapore.platform.restws");
        // sh.setInitParameter("com.Sun.jersey.config.property.packages",
        // "jetty");
        Server server = new Server(9999);

        ServletContextHandler context = new ServletContextHandler(server, "/",
            ServletContextHandler.SESSIONS);
        context.addServlet(sh, "/*");
        server.start();
        server.join();
        // Client c = Client.create();
        // WebResource r = c.resource("http://localhost:9999/");
        // System.out.println(r.get(String.class));
        //
        // server.stop();
    }
}

これでも機能しません。誰かが私に何か/チュートリアル/例を提案できますか?

14
rinku

ええと、リンクされたページは古いです-3年前の最後の更新。

本当に桟橋が必要ですか?ジャージーは、Glassfishトランスポート層としても機能するGrizzly( http://grizzly.Java.net を参照)との統合を徹底的にテストしており、例のように使用できます。

ジャージーワークスペースのhelloworldサンプルを参照してください。com.Sun.jersey.samples.helloworld.MainクラスはGrizzlyを起動し、helloworldアプリを「デプロイ」します。 http://repo1.maven.org/maven2/com/Sun/jersey/ samples/helloworld/1.9.1/helloworld-1.9.1-project.Zip

桟橋ベースのサンプルが本当に必要な場合は、提供できるはずです(お気軽にご連絡ください)。

編集:

さて、あなたが本当に桟橋が欲しいなら、あなたはそれを持つことができます:)そしてそれはかなり単純なように見えます。 http://docs.codehaus.org/display/JETTY/Embedding+Jetty の指示に従い、helloworldサンプルを開始できました。

public static void main(String[] args) throws Exception {
    Server server = new Server(8080);
    Context root = new Context(server,"/",Context.SESSIONS);
    root.addServlet(new ServletHolder(new ServletContainer(new PackagesResourceConfig("com.Sun.jersey.samples.helloworld"))), "/");
    server.start();
}

http:// localhost:8080/helloworld アクセス可能です。 Jetty6.1.16を使用しました。それが役に立てば幸い!

サーブレット環境でのJerseyの構成の詳細については、ユーザーガイドを参照してください。 http://jersey.Java.net/nonav/documentation/latest/

編集:

依存関係..しかし、これは特定するのが難しいです、それは最近ジャージーで変更されました..そう..

1.10より前:

<dependency>
    <groupId>org.mortbay.jetty</groupId>
    <artifactId>jetty</artifactId>
    <version>6.1.16</version>
</dependency>
<dependency>
     <groupId>com.Sun.jersey</groupId>
     <artifactId>jersey-server</artifactId>
     <version>${jersey.version}</version>
</dependency>

投稿1.10:

<dependency>
    <groupId>org.mortbay.jetty</groupId>
    <artifactId>jetty</artifactId>
    <version>6.1.16</version>
</dependency>
<dependency>
     <groupId>com.Sun.jersey</groupId>
     <artifactId>jersey-servlet</artifactId>
     <version>${jersey.version}</version>
</dependency>

桟橋にはこのMavenリポジトリが必要です。

<repositories>
    <repository>
        <id>codehaus-release-repo</id>
        <name>Codehaus Release Repo</name>
        <url>http://repository.codehaus.org</url>
    </repository>
</repositories>
18
Pavel Bucek

これは、マスターブランチのGrizzlyと「jetty」ブランチのJetty用に構成されたMavenベースのHelloWorldサンプルを含むgithubリポジトリです。

https://github.com/jesperfj/jax-rs-herok

リポジトリ名にもかかわらず、Heroku固有ではありません。 Procfileで指定されたコマンドを実行してサーバーを起動します。

$ Java -cp "target/dependency/*":target/classes Main
10
Jesper J.

Web.xmlなしのreaseasyを備えた埋め込み桟橋

Javaコード:

    final QueuedThreadPool threadPool = new QueuedThreadPool();
    threadPool.setMinThreads(2); // 10
    threadPool.setMaxThreads(8); // 200
    threadPool.setDetailedDump(false);
    threadPool.setName(SERVER_THREAD_POOL);
    threadPool.setDaemon(true);

    final SelectChannelConnector connector = new SelectChannelConnector();
    connector.setHost(Host);
    connector.setAcceptors(2);
    connector.setPort(PROXY_SEVLET_PORT);
    connector.setMaxIdleTime(MAX_IDLE_TIME);
    connector.setStatsOn(false);
    connector.setLowResourcesConnections(LOW_RESOURCES_CONNECTIONS);
    connector.setLowResourcesMaxIdleTime(LOW_RESOURCES_MAX_IDLE_TIME);
    connector.setName(HTTP_CONNECTOR_NAME);            

    /* Setup ServletContextHandler */
    final ServletContextHandler contextHandler = new ServletContextHandler(ServletContextHandler.SESSIONS);
    contextHandler.setContextPath("/");
    contextHandler.addEventListener(new ProxyContextListener());

    contextHandler.setInitParameter("resteasy.servlet.mapping.prefix","/services");

    final ServletHolder restEasyServletHolder = new ServletHolder(new HttpServletDispatcher());
    restEasyServletHolder.setInitOrder(1);

/* Scan package for web services*/
restEasyServletHolder.setInitParameter("javax.ws.rs.Application","com.viacom.pl.cprox.MessageApplication");

    contextHandler.addServlet(restEasyServletHolder, "/services/*");

    final HandlerList handlers = new HandlerList();
    handlers.setHandlers(new Handler[] { contextHandler });

    final Server server = new Server();
    server.setThreadPool(threadPool);
    server.setConnectors(new Connector[] { connector });
    server.setHandler(handlers);
    server.setStopAtShutdown(true);
    server.setSendServerVersion(true);
    server.setSendDateHeader(true);
    server.setGracefulShutdown(1000);
    server.setDumpAfterStart(false);
    server.setDumpBeforeStop(false);

    server.start();
    server.join();

Webサービス検出器:

package com.viacom.pl.cprox;

import Java.util.HashSet;
import Java.util.Set;

import javax.ws.rs.core.Application;

import org.reflections.Reflections;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import com.viacom.pl.cprox.services.impl.AbstractWebServiceMethod;

public class MessageApplication extends Application {

    private static final Logger LOGGER = LoggerFactory.getLogger(MessageApplication.class);

    private Set<Object> singletons = new HashSet<Object>();

    @SuppressWarnings("rawtypes")
    public MessageApplication() {

        /* Setup RestEasy */
        Reflections reflections = new Reflections("com.viacom.pl.cprox.services.impl");

        /*All my web services methods wrapper class extends AbstractWebServiceMethod, so it is easy to get sub set of expected result.*/
        Set<Class<? extends AbstractWebServiceMethod>> set = reflections
                .getSubTypesOf(AbstractWebServiceMethod.class);
        for (Class<? extends AbstractWebServiceMethod> clazz : set) {
            try {
                singletons.add(clazz.newInstance());
            } catch (InstantiationException e) {
                LOGGER.error(e.getMessage(), e);
            } catch (IllegalAccessException e) {
                LOGGER.error(e.getMessage(), e);
            }
        }
    }

    @Override
    public Set<Object> getSingletons() {
        return singletons;
    }
}

pom.xml

<dependency>
    <groupId>org.jboss.resteasy</groupId>
    <artifactId>resteasy-jaxb-provider</artifactId>
    <version>2.2.0.GA</version>
</dependency>
<dependency>
    <groupId>org.reflections</groupId>
    <artifactId>reflections</artifactId>
    <version>0.9.9-RC1</version>
</dependency>

<dependency>
    <groupId>org.jboss.resteasy</groupId>
    <artifactId>resteasy-jaxrs</artifactId>
    <version>3.0.3.Final</version>
</dependency>
4
Karol Król

このMavenアーキタイプを30分で稼働させることができました。

https://github.com/cb372/jersey-jetty-guice-archetype を参照してください

手順:

git clone https://github.com/cb372/jersey-jetty-guice-archetype.git
mvn install
mvn archetype:generate -DarchetypeGroupId=org.birchall \
    -DarchetypeArtifactId=jersey-jetty-guice-archetype -DarchetypeVersion=1.0
mvn compile exec:Java -Dexec.mainClass=com.yourpackage.Main

このアーキタイプを作成してくれたcb372に大いに感謝します。それはとても簡単になります。

2
Jess