package com.fasterxml.jackson.annotation; import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; /** * Marker annotation that indicates that the annotated method or field is to be * ignored by introspection-based serialization and deserialization * functionality. That is, it should not be consider a "getter", "setter" or * "creator". * <p> * In addition, starting with Jackson 1.9, if this is the only annotation * associated with a property, it will also cause cause the whole property to be * ignored: that is, if setter has this annotation and getter has no * annotations, getter is also effectively ignored. It is still possible for * different accessors to use different annotations; so if only "getter" is to * be ignored, other accessors (setter or field) would need explicit annotation * to prevent ignoral (usually {@link JsonProperty}). * <p> * For example, a "getter" method that would otherwise denote a property (like, * say, "getValue" to suggest property "value") to serialize, would be ignored * and no such property would be output unless another annotation defines * alternative method to use. * <p> * Before version 1.9, this annotation worked purely on method-by-method (or * field-by-field) basis; annotation on one method or field did not imply * ignoring other methods or fields. However, with version 1.9 and above, * annotations associated with various accessors (getter, setter, field, * constructor parameter) of a logical property are combined; meaning that * annotations in one (say, setter) can have effects on all of them (if getter * or field has nothing indicating otherwise). * <p> * Annotation is usually used just a like a marker annotation, that is, without * explicitly defining 'value' argument (which defaults to <code>true</code>): * but argument can be explicitly defined. This can be done to override an * existing JsonIgnore by explicitly defining one with 'false' argument. * <p> * Annotation is similar to {@link javax.xml.bind.annotation.XmlTransient} */ @Target({ ElementType.ANNOTATION_TYPE, ElementType.METHOD, ElementType.CONSTRUCTOR, ElementType.FIELD }) @Retention(RetentionPolicy.RUNTIME) @JacksonAnnotation public @interface JsonIgnore { /** * Optional argument that defines whether this annotation is active or not. * The only use for value 'false' if for overriding purposes (which is not * needed often); most likely it is needed for use with "mix-in annotations" * (aka "annotation overrides"). For most cases, however, default value of * "true" is just fine and should be omitted. */ boolean value() default true; }