L'annotation
@JsonFilter est utilisée pour définir des filtres personnalisés pour sérialiser les objets Java. Nous devons utiliser la classe FilterProvider pour définir le filtre et obtenir l'instance de filtre réelle. Configurez maintenant le filtre en attribuant le FilterProvider à la classe ObjectMapper .
@Target(value={ANNOTATION_TYPE,TYPE,METHOD,FIELD,PARAMETER}) @Retention(value=RUNTIME) public @interface JsonFilter
Dans l'exemple ci-dessous, customFilter peut être déclaré comme paramètre de l'annotation @JsonFilter, qui extrait uniquement le nom et filtre les autres attributs du bean.
import com.fasterxml.jackson.annotation.JsonFilter; import com.fasterxml.jackson.databind.ObjectMapper; import com.fasterxml.jackson.core.JsonProcessingException; import com.fasterxml.jackson.databind.ser.FilterProvider; import com.fasterxml.jackson.databind.ser.impl.SimpleBeanPropertyFilter; import com.fasterxml.jackson.databind.ser.impl.SimpleFilterProvider; public class JsonFilterAnnotationTest { public static void main(String args[]) throws JsonProcessingException { ObjectMapper mapper = new ObjectMapper(); FilterProvider filterProvider = new SimpleFilterProvider().addFilter("customFilter", SimpleBeanPropertyFilter.filterOutAllExcept("empName")); String jsonString = mapper.writer(filterProvider).writeValueAsString(new FilterBean()); System.out.println(jsonString); } } @JsonFilter("customFilter")<strong> </strong>class FilterBean { public int empId = 110; public String empName = "Raja Ramesh"; public String gender = "male"; }
{"empName":"Raja Ramesh"}
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!