@JsonFilter 맞춤 필터를 정의하는 데 사용되는 주석 Java 개체를 직렬화합니다. FilterProvider 를 사용해야 합니다. 필터를 정의하고 실제 필터 인스턴스를 가져오는 클래스입니다. 이제 FilterProvider 를 할당하여 필터를 구성했습니다. ObjectMapper 로 수업.
구문
@Target(value={ANNOTATION_TYPE,TYPE,METHOD,FIELD,PARAMETER}) @Retention(value=RUNTIME) public @interface JsonFilter
아래 예에서 customFilter @JsonFilter에 대한 인수로 선언할 수 있습니다. 주석은 이름만 추출하고 빈의 다른 속성은 필터링합니다.
예
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") class FilterBean { public int empId = 110; public String empName = "Raja Ramesh"; public String gender = "male"; }
출력
{"empName":"Raja Ramesh"}