Ce didacticiel explique comment utiliser les API clientes Jersey pour créer un client Java RESTful afin d’effectuer des requêtes « GET » et « POST » au service REST créé dans ce lien://webservices/jax-rs/json-example-with-jersey-jackson/[Jersey Json]”par exemple.
1. Dépendance du client Jersey
Pour utiliser les API client Jersey, déclarez «
jersey-client.jar
» dans votre fichier
pom.xml
.
Fichier: pom.xml
<dependency> <groupId>com.sun.jersey</groupId> <artifactId>jersey-client</artifactId> <version>1.8</version> </dependency>
2. Demande GET
Consultez le dernier service REST.
@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; } //...
Le client Jersey doit envoyer une demande «GET» et imprimer les données JSON renvoyées.
package com.mkyong.client; import com.sun.jersey.api.client.Client; import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.WebResource; public class JerseyClientGet { public static void main(String[]args) { try { Client client = Client.create(); WebResource webResource = client .resource("http://localhost:8080/RESTfulExample/rest/json/metallica/get"); ClientResponse response = webResource.accept("application/json") .get(ClientResponse.class); if (response.getStatus() != 200) { throw new RuntimeException("Failed : HTTP error code : " + response.getStatus()); } String output = response.getEntity(String.class); System.out.println("Output from Server .... \n"); System.out.println(output); } catch (Exception e) { e.printStackTrace(); } } }
Sortie…
Output from Server .... {"singer":"Metallica","title":"Enter Sandman"}
3. Requête POST
Consultez le dernier service REST.
@Path("/json/metallica") public class JSONService { @POST @Path("/post") @Consumes(MediaType.APPLICATION__JSON) public Response createTrackInJSON(Track track) { String result = "Track saved : " + track; return Response.status(201).entity(result).build(); } //...
Client Jersey pour envoyer une demande "POST", avec données JSON et imprimer la sortie renvoyée.
package com.mkyong.client; import com.sun.jersey.api.client.Client; import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.WebResource; public class JerseyClientPost { public static void main(String[]args) { try { Client client = Client.create(); WebResource webResource = client .resource("http://localhost:8080/RESTfulExample/rest/json/metallica/post"); String input = "{\"singer\":\"Metallica\",\"title\":\"Fade To Black\"}"; ClientResponse response = webResource.type("application/json") .post(ClientResponse.class, input); if (response.getStatus() != 201) { throw new RuntimeException("Failed : HTTP error code : " + response.getStatus()); } System.out.println("Output from Server .... \n"); String output = response.getEntity(String.class); System.out.println(output); } catch (Exception e) { e.printStackTrace(); } } }
Sortie…
Output from Server .... Track saved : Track[title=Fade To Black, singer=Metallica].... === Télécharger le code source Téléchargez-le - lien://wp-content/uploads/2011/07/Jersey-Client-Example.zip[Jersey-Client-Example.zip](8 KB) === Références . lien://services web/jax-rs/exemple-json-avec-jersey-jackson/[JSON exemple avec Jersey Jackson]. http://blogs.oracle.com/enterprisetechtips/entry/consuming__restful__web__services__with[Jersey exemples de clients]. lien://services web/jax-rs/framework-repos-java-client-with-resteasy-client/[RESTful Client Java avec infrastructure client RESTEasy]. lien://services web/jax-rs/restfull-client-java-avec-java-net-url/[RESTful Client Java avec java.net.URL]. lien://services web/jax-rs/reposful-client-java-avec-apache-httpclient/[RESTful Client Java avec Apache HttpClient] lien://tag/client/[client]lien://tag/jax-rs/[jax-rs]lien://tag/jersey/[jersey]lien://tag/reposant/[reposant]