Jersey verwendet Jackson, um object in JSON umzuwandeln. In diesem Lernprogramm zeigen wir Ihnen, wie Sie ein "Track" -Objekt in das JSON-Format konvertieren und es an den Benutzer zurückgeben.
1. Abhängigkeit
Damit Jersey JSON-Mapping unterstützt, wird " jersey-json.jar " in der Maven-Datei "pom.xml" angegeben.
<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. Integrieren Sie JSON mit Jersey
In
web.xml
deklariert„ com.sun.jersey.api.json.POJOMappingFeature` “als„ init-param “in einem Jersey-zugeordneten Servlet. Jersey wird JSON/Objekt-Mapping unterstützen.
<init-param> <param-name>com.sun.jersey.api.json.POJOMappingFeature</param-name> <param-value>true</param-value> </init-param>
Datei: web.xml - vollständiges Beispiel.
<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. Einfaches Objekt
Ein einfaches "Track" -Objekt, später Jersey, konvertiert es in das JSON-Format.
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 + "]"; } }
-
JAX-RS mit Trikot
Annotieren Sie die Methode mit @Produces (MediaType.APPLICATION__JSON) `. Jersey verwendet Jackson, um die JSON-Konvertierung automatisch durchzuführen.
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. Demo
Siehe Demo für GET- und POST-Anforderung.
-
1. GET-Methode Wenn das URI-Muster „ /json/metallica/get ** “ angefordert wird, wird der klassische Metallica-Song „Enter Sandman“ im JSON-Format zurückgegeben.
{ "singer":"Metallica", "title":"Enter Sandman" }
-
2. POST-Methode + Zum Testen der Post-Anforderung können Sie einen RESTful-Client erstellen (siehe folgenden Link://webservices/jax-rs/restful-java-client-with-jersey-client/[Beispiel für Jersey-Client-APIs]) und Wenn Sie den json-Formatstring in das URI-Muster „ /json/metallica/post ** “ schreiben, wird der veröffentlichte json-String automatisch in ein „Track“ -Objekt konvertiert.
Quellcode herunterladen
Download es - JSON-Support-Jersey-Example.zip (7 KB)
Referenzen
Unterstützung in Jersey]