@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"}