Джерси использует Джексона для преобразования объекта в/формирует JSON . В этом руководстве мы покажем вам, как преобразовать объект «Track» в формат JSON и вернуть его пользователю.
1. Зависимость
Чтобы Джерси поддерживал отображение JSON, объявите «
jersey-json.jar
» в файле Maven
pom.xml
.
<dependency> <groupId>com.sun.jersey</groupId> <artifactId>jersey-server</artifactId> <version>1.8</version> </dependency> <dependency> <groupId>com.sun.jersey</groupId> <artifactId>jersey-json</artifactId> <version>1.8</version> </dependency>
2. Интегрировать JSON с Джерси
В
web.xml
объявляет« com.sun.jersey.api.json.POJOMappingFeature` »как« init-param »в отображаемом сервлете Джерси. Это заставит Джерси поддерживать JSON/сопоставление объектов.
<init-param> <param-name>com.sun.jersey.api.json.POJOMappingFeature</param-name> <param-value>true</param-value> </init-param>
File: web.xml - полный пример.
<web-app ...> <servlet> <servlet-name>jersey-serlvet</servlet-name> <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class> <init-param> <param-name>com.sun.jersey.config.property.packages</param-name> <param-value>com.mkyong.rest</param-value> </init-param> <init-param> <param-name>com.sun.jersey.api.json.POJOMappingFeature</param-name> <param-value>true</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>jersey-serlvet</servlet-name> <url-pattern>/rest/** </url-pattern> </servlet-mapping> </web-app>
3. Простой объект
Простой объект «Track», позже Джерси преобразует его в формат JSON.
package com.mkyong; public class Track { String title; String singer; public String getTitle() { return title; } public void setTitle(String title) { this.title = title; } public String getSinger() { return singer; } public void setSinger(String singer) { this.singer = singer; } @Override public String toString() { return "Track[title=" + title + ", singer=" + singer + "]"; } }
4. JAX-RS с Джерси
Аннотируйте метод с помощью
@Produces (MediaType.APPLICATION__JSON)
. Джерси будет использовать Джексона для автоматической обработки преобразования JSON.
package com.mkyong.rest; import javax.ws.rs.Consumes; import javax.ws.rs.GET; import javax.ws.rs.POST; import javax.ws.rs.Path; import javax.ws.rs.Produces; import javax.ws.rs.core.MediaType; import javax.ws.rs.core.Response; import com.mkyong.Track; @Path("/json/metallica") public class JSONService { @GET @Path("/get") @Produces(MediaType.APPLICATION__JSON) public Track getTrackInJSON() { Track track = new Track(); track.setTitle("Enter Sandman"); track.setSinger("Metallica"); return track; } @POST @Path("/post") @Consumes(MediaType.APPLICATION__JSON) public Response createTrackInJSON(Track track) { String result = "Track saved : " + track; return Response.status(201).entity(result).build(); } }
5. Демо
Смотрите демо для GET и POST запроса.
-
1. Метод GET При запросе шаблона URI « /json/metallica/get ** » классическая песня Metallica «Enter Sandman» будет возвращена в формате JSON.
{ "singer":"Metallica", "title":"Enter Sandman" }
-
2. Метод POST Чтобы протестировать пост-запрос, вы можете создать клиент RESTful (см. Эту ссылку://webservices/jax-rs/restful-java-client-with-jersey-client/[пример API-интерфейса клиента Джерси]) и « после отправки строки формата json в шаблон URI « /json/metallica/post ** » опубликованная строка json автоматически преобразуется в объект «Отслеживание».
Скачать исходный код
Загрузите его - ссылка://wp-content/uploads/2011/07/JSON-Support-Jersey-Example.zip[JSON-Support-Jersey-Example.zip](7 КБ)
Рекомендации
Поддержка в Джерси]
ссылка://тег/интеграция/[интеграция]ссылка://тег/джексон/[джексон]ссылка://тег/jax-rs/[jax-rs]ссылка://тег/джерси/[джерси]ссылка://тег/JSON/[JSON]