Spring에서 ObjectMapper 구성
Spring 애플리케이션에서 ObjectMapper는 JSON 데이터를 직렬화 및 역직렬화하는 데 중요한 구성 요소입니다. @JsonProperty로 주석이 달린 속성만 직렬화하는 등 특정 요구 사항을 충족하도록 ObjectMapper를 사용자 정의할 수 있습니다.
이를 달성하기 위한 첫 번째 단계는 Jackson에서 제공하는 기본 ObjectMapper 클래스를 확장하는 사용자 정의 ObjectMapper 클래스를 생성하는 것입니다. 주석이 달린 속성을 제외하도록 기본 가시성 검사기를 재정의합니다.
public class MyCustomObjectMapper extends ObjectMapper { public MyCustomObjectMapper() { super(); setVisibilityChecker(getSerializationConfig() .getDefaultVisibilityChecker() .withCreatorVisibility(JsonAutoDetect.Visibility.NONE) .withFieldVisibility(JsonAutoDetect.Visibility.NONE) .withGetterVisibility(JsonAutoDetect.Visibility.NONE) .withIsGetterVisibility(JsonAutoDetect.Visibility.NONE) .withSetterVisibility(JsonAutoDetect.Visibility.DEFAULT)); } }
다음으로 Spring 구성 파일(servlet.xml)에 사용자 정의 ObjectMapper Bean을 등록합니다.
<bean>
마지막으로, 사용자 정의 ObjectMapper를 사용하도록 주석 기반 MVC 프레임워크를 구성합니다.
<bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"> <property name="messageConverters"> <list> <bean class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter"> <property name="objectMapper" ref="customObjectMapper" /> </bean> </list> </property> </bean>
예제 코드에서 제공된 경우 NumbersOfNewEvents 클래스에는 두 개의 공개 속성이 포함됩니다.
public class NumbersOfNewEvents implements StatusAttribute { public Integer newAccepts; public Integer openRequests; // ... }
그러나 newAccepts 속성만 @JsonProperty로 주석 처리됩니다.
@JsonProperty public Integer newAccepts;
위에 설명된 대로 ObjectMapper를 구성하면 NumbersOfNewEvents 개체가 JSON으로 변환될 때 newAccepts 특성을 직렬화해야 합니다. 이는 사용자 정의 ObjectMapper가 직렬화 중에 주석이 지정되지 않은 속성을 제외하기 때문입니다.
위 내용은 @JsonProperty 주석이 달린 속성만 직렬화하도록 Spring의 ObjectMapper를 사용자 정의하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!