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();
}
}
これでも機能しません。誰かが私に何か/チュートリアル/例を提案できますか?
ええと、リンクされたページは古いです-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>
これは、マスターブランチのGrizzlyと「jetty」ブランチのJetty用に構成されたMavenベースのHelloWorldサンプルを含むgithubリポジトリです。
https://github.com/jesperfj/jax-rs-herok
リポジトリ名にもかかわらず、Heroku固有ではありません。 Procfileで指定されたコマンドを実行してサーバーを起動します。
$ Java -cp "target/dependency/*":target/classes Main
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>
この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に大いに感謝します。それはとても簡単になります。