web-dev-qa-db-ja.com

Tomcat8にJersey2.xを実装するための最良のアプローチは何ですか?

WebコンテナとTomcatの知識があり、静的および動的なWebサイトをデプロイできます。しかし、私はRESTとジャージーに不慣れです。2.6ユーザーガイドを読み、多くのサイトとYouTubeビデオを確認しました。1.xジャージーについては多くの情報があるようですが、あまり多くはありません。 2.x 1.18を自分の環境で動作させることはできますが、展開モデルを2.xで動作させることができないようです。2.xにアプリケーション展開モデルがあることに気づきました。非常に一般的な質問をするつもりでした。これを始めるために。

  1. Tomcat8を介した基本的なRESTサービスに最適なデプロイメントモデルとその理由は何ですか?
  2. 2.6でデプロイされた.jarは、1.18でデプロイされたものとは大きく異なることがわかります。基本的なTomcatのインストールに必要なjarを簡単に判断する方法はありますか?
  3. 基本的な例があれば、それは素晴らしいことです。

ありがとう

13
rss181919

以下は、あなたの質問に対する比較的完全な解決策であることを願っています。

Mavenについては言及していないので、次のようにします。Mavenはここでの友達です。

pomから始めましょう:

_<project xmlns="http://maven.Apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://maven.Apache.org/POM/4.0.0 http://maven.Apache.org/maven-v4_0_0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>com.example.groupid</groupId>
  <artifactId>stack</artifactId>
  <packaging>war</packaging>
  <version>0.0.1-SNAPSHOT</version>
  <url>http://maven.Apache.org</url>
  <dependencies>
    <dependency>
      <groupId>javax.servlet</groupId>
      <artifactId>javax.servlet-api</artifactId>
      <version>3.1.0</version>
      <scope>provided</scope>
    </dependency>
    <dependency>
      <groupId>org.glassfish.jersey.containers</groupId>
      <artifactId>jersey-container-servlet-core</artifactId>
      <version>2.13</version>
    </dependency>
    <dependency>
      <groupId>org.glassfish.jersey.containers</groupId>
      <artifactId>jersey-container-servlet</artifactId>
      <version>2.13</version>
    </dependency>
  </dependencies>
  <build>
    <finalName>stack</finalName>
    <plugins>
      <plugin>
        <groupId>org.Apache.maven.plugins</groupId>
        <artifactId>maven-war-plugin</artifactId>
        <version>2.5</version>
      </plugin>

      <plugin>
        <groupId>org.Apache.maven.plugins</groupId>
        <artifactId>maven-compiler-plugin</artifactId>
        <version>3.2</version>
        <configuration>
          <source>1.8</source>
          <target>1.8</target>
        </configuration>
      </plugin>
    </plugins>
  </build>
  <name>Stack</name>
</project>
_

これは依存関係の観点からは絶対的な最小値ではないかもしれませんが、近いです。

しかし、それはただのポンです。トリックはweb.xmlとJavaクラスで続きます。

そのweb.xmlについて...

それはめちゃくちゃ複雑なので、我慢してください:

_<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee" 
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee
                             http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
         metadata-complete="false"
         version="3.1">
</web-app>
_

わかりました、多分それほど複雑ではありません。

_metadata-complete="true"_を設定すると、Tomcatの起動が速くなる可能性があることに注意してください。

Javaクラスのペア

1つは「アプリケーション」で、もう1つは残りの呼び出しです。***

残りの呼び出しは非常に簡単です。

_package some.package;

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

@Path("/hello")
public class HelloRest {

  @GET
  public String message() {
    return "Hello, rest!";
  }
}
_

アプリケーションは次のようになります。

_package some.package;

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

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

import some.package.HelloRest;

@ApplicationPath("/rest")
public class RestApp extends Application {
  public Set<Class<?>> getClasses() {
    return new HashSet<Class<?>>(Arrays.asList(HelloRest.class));
  }
}
_

以上です。 _http://localhost:8080/stack/rest/hello_のようなものに移動すると、「Hello、rest!」というテキストが表示されます。

ジャージーを少し活用してください。

RestAppのgetClasses()は少し醜いです。 Jerseyユーザーガイド のように、JerseyのResourceConfigを使用すると、次のようになります。

_public class RestApp extends ResourceConfig {
    public RestApp() {
        packages("some.package");
    }
}
_

しかし、Mavenは使いたくない!

結構です。これらは、EclipseがMaven依存関係としてリストするjarです。

  • javax.servlet-api-3.1.0.jar
  • jersey-container-servlet-core-2.13.jar
  • javax.inject-2.3.0-b10.jar
  • jersey-common-2.13.jar
  • javax.annotation-api-1.2.jar
  • ジャージ-グアバ-2.13.jar
  • hk2-api-2.3.0-b10.jar
  • hk2-utils-2.3.0-b10.jar
  • aopalliance-repackaged-2.3.0-b10.jar
  • hk2-locator-2.3.0-b10.jar
  • javassist-3.18.1-GA.jar
  • osgi-resource-locator-1.0.1.jar
  • jersey-server-2.13.jar
  • jersey-client-2.13.jar
  • 検証-api-1.1.0.Final.jar
  • javax.ws.rs-api-2.0.1.jar
  • jersey-container-servlet-2.13.jar

おそらく、それらをクラスパスに手動で追加することは機能するはずです。または、Mavenを使用します。

40
6cef

3.xサーブレットコンテナにデプロイするためのJersey2.6ユーザーガイドに記載されている手順を使用して、これを機能させることができました。結局、以下のようなものを使用しました。 URLマッピングは.xmlで提供されるため、Applicationサブクラスから@ApplicationPathを省略できます。

<web-app version="3.0"
    xmlns="http://Java.Sun.com/xml/ns/javaee"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">

    <!-- Servlet declaration can be omitted in which case
         it would be automatically added by Jersey -->
    <servlet>
        <servlet-name>org.example.MyApplication</servlet-name>
    </servlet>

    <!-- Servlet mapping can be omitted in case the Application subclass
         is annotated with @ApplicationPath annotation; in such case
         the mapping would be automatically added by Jersey -->
    <servlet-mapping>
        <servlet-name>org.example.MyApplication</servlet-name>
        <url-pattern>/myresources/*</url-pattern>
    </servlet-mapping>
</web-app>
1
rss181919