jersey
JerseyでのJAX-RSの設定
サーチ…
クロス・オリジン・リクエスト用JavaジャージーCORSフィルタ
@Provider
public class CORSResponseFilter implements ContainerResponseFilter {
public void filter(
ContainerRequestContext requestContext,
ContainerResponseContext responseContext
) throws IOException {
MultivaluedMap<String, Object> headers = responseContext.getHeaders();
headers.add("Access-Control-Allow-Origin", "*"); //Allow Access from everywhere
headers.add("Access-Control-Allow-Methods", "GET, POST, DELETE, PUT");
headers.add("Access-Control-Allow-Headers", "X-Requested-With, Content-Type");
}
}
Access-Control-Allow-Originは、OPTIONS応答でのみ有効であることに注意してください。
Javaジャーナル構成
この例では、JerseyをRESTful API用のJAX-RS実装フレームワークとして使用するようにJerseyを構成する方法を示します。
すでにApache Mavenをインストールしていると仮定して、Jerseyを設定するには次の手順に従います。
- Maven Webプロジェクト構造を作成し、端末(ウィンドウ)で以下のコマンドを実行します
mvn archetype:generate -DgroupId = com.stackoverflow.rest -DartifactId = jersey-ws-demo -DarchetypeArtifactId = maven-archetype-webapp -DinteractiveMode = false
注: Eclipseをサポートするには、Mavenコマンドを使用します。mvn eclipse:eclipse -Dwtpversion = 2.0
- pom.xmlにmavenプロジェクトを作成したフォルダに移動し、必要な依存関係を追加します
<dependencies>
<!-- Jersey 2.22.2 -->
<dependency>
<groupId>org.glassfish.jersey.containers</groupId>
<artifactId>jersey-container-servlet</artifactId>
<version>${jersey.version}</version>
</dependency>
<!-- JSON/POJO support -->
<dependency>
<groupId>org.glassfish.jersey.media</groupId>
<artifactId>jersey-media-json-jackson</artifactId>
<version>${jersey.version}</version>
</dependency>
</dependencies>
<properties>
<jersey.version>2.22.2</jersey.version>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
- Web.xmlに次のコードを追加します
<servlet>
<servlet-name>jersey-serlvet</servlet-name>
<servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
<init-param>
<param-name>jersey.config.server.provider.packages</param-name>
<!-- Service or resources to be placed in the following package -->
<param-value>com.stackoverflow.service</param-value>
</init-param>
<!-- Application configuration, used for registering resources like filters -->
<init-param>
<param-name>javax.ws.rs.Application</param-name>
<param-value>com.stackoverflow.config.ApplicationConfig</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<!-- Url mapping, usage-http://domainname:port/appname/api/ -->
<servlet-mapping>
<servlet-name>jersey-serlvet</servlet-name>
<url-pattern>/api/*</url-pattern>
</servlet-mapping>
-
ApplicationConfig
クラス
public class ApplicationConfig extends ResourceConfig {
public ApplicationConfig() {
register(OtherStuffIfNeeded.class);
}
}
また、 web.xmlを使用しない場合は、 ApplicationConfig
クラスの上に@ApplicationPath("/api")
を追加するだけで済みます。
@ApplicationPath("/api")
public class ApplicationConfig extends ResourceConfig {
public ApplicationConfig() {
// this call has the same effect as
// jersey.config.server.provider.packages
// in the web.xml: it scans that packages for resources and providers.
packages("com.stackoverflow.service");
}
}
- あなたのMavenプロジェクトをビルドしてデプロイします。
- Java RESTful Webサービス(JAX-RS)クラスを設定して、Jerseyのjarを使用できるようになりました。
Modified text is an extract of the original Stack Overflow Documentation
ライセンスを受けた CC BY-SA 3.0
所属していない Stack Overflow