Jackson JSON: difference between @JsonIgnore and @JsonIgnoreProperties annotations (2024)

Jackson has two different annotations to use when you want to exclude some class members from the JSON serialization and deserialization processes. These two annotations are @JsonIgnore and @JsonIgnoreProperties.
@JsonIgnoreProperties is an annotation at the class level and it expects that the properties to be excluded would be explicitly indicated in the form of a list of strings.
@JsonIgnore instead is a member-level or method-level annotation, which expects that the properties to be excluded are marked one by one. To completely exclude a member from the process of serialization and de-serialization it’s possibile to annotate the actual property or its setter or its getter. (This behavior is in force since version 1.9 of Jackson). It’s also possible to exclude properties in an asymmetrical way between serialization and deserialization, but we’ll see an example of this case in another post.

Now let’s see a concrete example of use of these annotations. We create a class MyTestClass with some properties and the related getters and setters and a simple test class in which we create an object of that class and then we perform its JSON serialization and deserialization.
We start with an example using the class as-is, without annotations which exclude certain properties.

import java.io.IOException;import com.fasterxml.jackson.core.JsonParseException;import com.fasterxml.jackson.core.JsonProcessingException;import com.fasterxml.jackson.databind.JsonMappingException;import com.fasterxml.jackson.databind.ObjectMapper;class MyTestClass { private long id; private String name; private String notInterstingMember; private int anotherMember; private int forgetThisField; public long getId() { return this.id; } public void setId(long id) { this.id = id; } public String getName() { return this.name; } public void setName(String name) { this.name = name; } public String getNotInterstingMember() { return this.notInterstingMember; } public void setNotInterstingMember(String notInterstingMember) { this.notInterstingMember = notInterstingMember; } public int getAnotherMember() { return this.anotherMember; } public void setAnotherMember(int anotherMember) { this.anotherMember = anotherMember; } public int getForgetThisField() { return this.forgetThisField; } public void setForgetThisField(int forgetThisField) { this.forgetThisField = forgetThisField; } @Override public String toString() { return "MyTestClass [" + this.id + " , " + this.name + ", " + this.notInterstingMember + ", " + this.anotherMember + ", " + this.forgetThisField + "]"; }}public class JSONIgnorePropTest { public static void main(String[] args) { ObjectMapper mapper = new ObjectMapper(); MyTestClass mtc = new MyTestClass(); mtc.setId(1); mtc.setName("Test program"); mtc.setNotInterstingMember("Don't care about this"); mtc.setAnotherMember(100); mtc.setForgetThisField(-1); String s = null; try { s = mapper.writeValueAsString(mtc); } catch (JsonProcessingException e) { // TODO Auto-generated catch block e.printStackTrace(); } System.out.println(s); MyTestClass mtc2 = null; try { mtc2 = mapper.readValue(s, MyTestClass.class); } catch (JsonParseException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (JsonMappingException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } System.out.println(mtc2.toString()); }}

The result of this first run is the following, in which all the fields and their values are serialized and then “reconstructed” during deserialization.

{"id":1,"name":"Test program","notInterstingMember":"Don't care about this","anotherMember":100,"forgetThisField":-1}MyTestClass [1 , Test program, Don't care about this, 100, -1]

Now suppose you want to exclude from the results of serialization and deserialization some of the class MyTestClass properties, for instance the “notInterstingMember” and “forgetThisField” properties. As first case we see how to achieve this with the @JsonIgnoreProperties annotation. To do that we have to change our MyTestClass class as follows:

@JsonIgnoreProperties({"notInterstingMember", "forgetThisField"})class MyTestClass { private long id; private String name; private String notInterstingMember; private int anotherMember; private int forgetThisField;// REST OF THE CODE...}

By running the program again, this time we get the following result:

{"id":1,"name":"Test program","anotherMember":100}MyTestClass [1 , Test program, null, 100, 0]

As we can see, in the string produced by the serialization process are not present the values of the properties that we have indicated to exclude through the annotation. After the deserialization therefore, these properties assume the default value provided by their type, then “null” for the String property and 0 for the int property.

The same result can also be obtained using the other annotation, @JsonIgnore which, as mentioned, is not a “class-level” annotation but a “member-level” or “method-level” one. Let’s change again our example class as follows:

class MyTestClass {private long id;private String name;@JsonIgnoreprivate String notInterstingMember;private int anotherMember;@JsonIgnoreprivate int forgetThisField;// REST OF THE CODE}

By running the program again we can see that the result is the same as in the previous case.

{"id":1,"name":"Test program","anotherMember":100}MyTestClass [1 , Test program, null, 100, 0]

As we said at the beginning of the post, to accomplish this result using the @JsonIgnore annotation, it can be put directly on the instance member or on its getter or its setter. The application of the annotation in any of these 3 points, leads to the total exclusion of the property from both the serialization and de-serialization processes (this applies starting from Jackson 1.9; the version used in these examples is Jackson 2.4.3).
It’s possible to change this behavior and make it asymmetric, for example to exclude a property only from the deserialization using the @JsonIgnore annotation together with another annotation called @JsonProperty.

In the following example we annotate with @JsonIgnore the getter of the “notInterstingMember” property and the setter of the “forgetThisField” property (without annotate the property itself). How can we see the result is once again equal to those from previous examples.

import java.io.IOException;import com.fasterxml.jackson.annotation.JsonIgnore;import com.fasterxml.jackson.core.JsonParseException;import com.fasterxml.jackson.core.JsonProcessingException;import com.fasterxml.jackson.databind.JsonMappingException;import com.fasterxml.jackson.databind.ObjectMapper;class MyTestClass { private long id; private String name; private String notInterstingMember; private int anotherMember; private int forgetThisField; public long getId() { return this.id; } public void setId(long id) { this.id = id; } public String getName() { return this.name; } public void setName(String name) { this.name = name; } @JsonIgnore public String getNotInterstingMember() { return this.notInterstingMember; } public void setNotInterstingMember(String notInterstingMember) { this.notInterstingMember = notInterstingMember; } public int getAnotherMember() { return this.anotherMember; } public void setAnotherMember(int anotherMember) { this.anotherMember = anotherMember; } public int getForgetThisField() { return this.forgetThisField; } @JsonIgnore public void setForgetThisField(int forgetThisField) { this.forgetThisField = forgetThisField; } @Override public String toString() { return "MyTestClass [" + this.id + " , " + this.name + ", " + this.notInterstingMember + ", " + this.anotherMember + ", " + this.forgetThisField + "]"; }}
{"id":1,"name":"Test program","anotherMember":100}MyTestClass [1 , Test program, null, 100, 0]

See also:

  • Jackson: using @JsonSerialize (or @JsonDeserialize) annotation to register a custom serializer (or deserializer)
  • Jackson JSON: deserialize a list of objects of subclasses of an abstract class
  • Jackson:how to exclude null value properties from JSON serialization

The code of the 3 different examples described in the post can be downloaded here:

Jackson JSON: difference between @JsonIgnore and @JsonIgnoreProperties annotations (1)

Jackson JsonIgnore examples

1 file(s) 2.62 KB

Download

Jackson JSON: difference between @JsonIgnore and @JsonIgnoreProperties annotations (2024)
Top Articles
Baldur's Gate 3: Why the Bloodthirst Dagger is a Must-Have for Any Rogue Character
Baldur's Gate 3: How to Get the Ritual Dagger
3Movierulz
Tampa Fl Craigslist
57 Freeway Accident Today 2023
General Aviation Terminal / GAT
Cleveland Clinic Named No. 2 Hospital in Nation and No. 1 Hospital for Heart Care by U.S. News & World Report
SUN WOOD ➠ the ultimate alternative to reclaimed wood & precious wood
Katinakay Leaks
Qmx Airport
Carbs in Nalley Tartar Sauce
Dial Murray Obituaries Moncks Corner Sc
1998 Pontiac Firebird Trans Am for sale - Denver, CO - craigslist
Xk Class Scenario
Kiddle Encyclopedia
2068032104
Why Do Two Porsche Bucket Seats Cost More Than An Entire Boxster And An Entire Cayenne Combined? - The Autopian
Bible Gateway passage: John 6 - New International Version
The Creator Showtimes Near Regal La Live
Www Acpny Com Login
Adventhealth Centra Care Horizon West Reviews
Android için OGWhatsApp Apk v19.41.1'i İndirin (En Son)
Amerideck Cost
Page 1328 – Christianity Today
Veronica Correia titt*es
Marcus Roberts 1040 Answers
Home Depot Roto Rooter Rental
Registered Nurse Outpatient Case Manager Healthcare WellMed San Antonio Texas in San Antonio, TX for Optum
Plane 123Movie
CUE 2016 National Conference Schedule
The Little Mermaid 2023 Showtimes Near Cinemark Downey And Xd
Costco Gas Kingman Az
10 War Movies That Angered Military Experts and Veterans
Co Parts Mn
Cheap Car Rentals in Mexico from just $5 | momondo
Quest Diagnostics Mt Morris Appointment
Brenda Song Wikifeet
U Miami Health Chart
Musas Tijuana
Large Pawn Shops Near Me
Registrar - New York Law School
Soap Central Message Boards Bold And Beautiful
Bmw 328i e46 - oferte
My Name Is Glenn Quagmire Lyrics
Goanimate Gina Delgado
Gym Cerca De Mí
Integral Calculator: Step-by-Step Solutions - Wolfram|Alpha
Craigslist For Southeast Missouri
K9Girllzz
The Complete list of all Supermarkets in Curaçao  | Exploring Curaçao
R/Clashroyale
Latest Posts
Article information

Author: Saturnina Altenwerth DVM

Last Updated:

Views: 5927

Rating: 4.3 / 5 (64 voted)

Reviews: 95% of readers found this page helpful

Author information

Name: Saturnina Altenwerth DVM

Birthday: 1992-08-21

Address: Apt. 237 662 Haag Mills, East Verenaport, MO 57071-5493

Phone: +331850833384

Job: District Real-Estate Architect

Hobby: Skateboarding, Taxidermy, Air sports, Painting, Knife making, Letterboxing, Inline skating

Introduction: My name is Saturnina Altenwerth DVM, I am a witty, perfect, combative, beautiful, determined, fancy, determined person who loves writing and wants to share my knowledge and understanding with you.