Jersey utilise Jackson pour convertir objet en/formulaire JSON . Dans ce tutoriel, nous vous montrons comment convertir un objet «Track» au format JSON et le renvoyer à l’utilisateur.
1. Dépendance
Pour que le mappage JSON soit pris en charge par Jersey, déclare «
jersey-json.jar
» dans le fichier 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. Intégrer JSON avec Jersey
Dans
web.xml
, déclare«
com.sun.jersey.api.json.POJOMappingFeature
» comme «` init-param` »dans le servlet mappé de Jersey. Cela permettra à Jersey de prendre en charge le mappage JSON/objet.
<init-param>
<param-name>com.sun.jersey.api.json.POJOMappingFeature</param-name>
<param-value>true</param-value>
</init-param>
File: web.xml - exemple complet.
<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. Objet simple
Un simple objet «Track», plus tard, Jersey le convertira au format 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 avec Jersey
Annotez la méthode avec
@Produces (MediaType.APPLICATION__JSON)
. Jersey utilisera Jackson pour gérer la conversion JSON automatiquement.
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. Démo
Voir la démo pour les requêtes GET et POST.
-
1. Méthode GET Lorsque le motif URI “ /json/metallica/get ** ” est demandé, la chanson classique de Metallica “Enter Sandman” est renvoyée au format JSON.
{
"singer":"Metallica",
"title":"Enter Sandman"
}
-
2. Méthode POST Pour tester une demande de publication, vous pouvez créer un client RESTful (voir le lien suivant: Webservices/jax-rs/restful-java-client-with-jersey-client/[exemple d’API client Jersey]), et « post ”de la chaîne de format json au modèle d’URI“ /json/metallica/post ** “, la chaîne json publiée sera automatiquement convertie en objet“ Suivi ”.
Télécharger le code source
Téléchargez le - lien://wp-content/uploads/2011/07/JSON-Support-Jersey-Example.zip[JSON-Support-Jersey-Example.zip](7 KB)
Références
Soutien à Jersey]
lien://tag/intégration/[intégration]lien://tag/jackson/[jackson]lien://tag/jax-rs/[jax-rs]lien://tag/jersey/[jersey]lien://tag/json/[json]