JSON Example With Jersey + Jackson

http://www.mkyong.com/webservices/jax-rs/json-example-with-jersey-jackson/


Jersey uses Jackson to convert object to / form JSON. In this tutorial, we show you how to convert a “Track” object into JSON format, and return it back to user.

1. Dependency

To make Jersey support JSON mapping, declares “jersey-json.jar” in Maven pom.xml file.

	<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>
Note
Review the downloaded dependencies in your project classpath, Jackson and related libraries are inlcuded.
2. Integrate JSON with Jersey

In web.xml, declares “com.sun.jersey.api.json.POJOMappingFeature” as “init-param” in Jersey mapped servlet. It will make Jersey support JSON/object mapping.

	<init-param>
		<param-name>com.sun.jersey.api.json.POJOMappingFeature</param-name>
		<param-value>true</param-value>
	</init-param>

File : web.xml - full example.

<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. Simple Object

A simple “Track” object, later Jersey will convert it into JSON format.

  1. package com.mkyong;
  2.  
  3. public class Track {
  4.  
  5. String title;
  6. String singer;
  7.  
  8. public String getTitle() {
  9. return title;
  10. }
  11.  
  12. public void setTitle(String title) {
  13. this.title = title;
  14. }
  15.  
  16. public String getSinger() {
  17. return singer;
  18. }
  19.  
  20. public void setSinger(String singer) {
  21. this.singer = singer;
  22. }
  23.  
  24. @Override
  25. public String toString() {
  26. return "Track [title=" + title + ", singer=" + singer + "]";
  27. }
  28.  
  29. }
4. JAX-RS with Jersey

Annotate the method with @Produces(MediaType.APPLICATION_JSON). Jersey will use Jackson to handle the JSON conversion automatically.

  1. package com.mkyong.rest;
  2.  
  3. import javax.ws.rs.Consumes;
  4. import javax.ws.rs.GET;
  5. import javax.ws.rs.POST;
  6. import javax.ws.rs.Path;
  7. import javax.ws.rs.Produces;
  8. import javax.ws.rs.core.MediaType;
  9. import javax.ws.rs.core.Response;
  10.  
  11. import com.mkyong.Track;
  12.  
  13. @Path("/json/metallica")
  14. public class JSONService {
  15.  
  16. @GET
  17. @Path("/get")
  18. @Produces(MediaType.APPLICATION_JSON)
  19. public Track getTrackInJSON() {
  20.  
  21. Track track = new Track();
  22. track.setTitle("Enter Sandman");
  23. track.setSinger("Metallica");
  24.  
  25. return track;
  26.  
  27. }
  28.  
  29. @POST
  30. @Path("/post")
  31. @Consumes(MediaType.APPLICATION_JSON)
  32. public Response createTrackInJSON(Track track) {
  33.  
  34. String result = "Track saved : " + track;
  35. return Response.status(201).entity(result).build();
  36.  
  37. }
  38.  
  39. }
5. Demo

See demo for GET and POST request.

1. GET method
When URI pattern “/json/metallica/get” is requested, the Metallica classic song “Enter Sandman” will be returned in JSON format.

{
	"singer":"Metallica",
	"title":"Enter Sandman"
}
json jersey demo

2. POST method
To test post request, you can create a RESTful client (refer to this Jersey client APIs example), and “post” the json format string to URI pattern “/json/metallica/post“, the posted json string will be converted into “Track” object automatically.

Download Source Code
Download it –  JSON-Support-Jersey-Example.zip (7 KB)
References
  1. Jackson Official Website
  2. JSON Support in Jersey