목차

Java Jackson JSON Library

@JsonView

@JsonCreator

public class Customer {
    private String id;
    private String name;
    private String address;
 
    public Customer() {
    }
 
    @JsonCreator
    public Customer(
            @JsonProperty("id") String id, 
            @JsonProperty("fullname") String name,
            @JsonProperty("location") String address) {
        System.out.println("run constructor...");
        this.id = id;
        this.name = name;
        this.address = address;
    }
 
    @Override
    public String toString() {
        return "Customer [id=" + id + ", name=" + name + ", address=" + address + "]";
    }
}

Performance

Config 설정

ObjectMapper objectMapper = new ObjectMapper();
 
objectMapper
  // 모르는 property에 대해 무시하고 넘어간다. DTO의 하위 호환성 보장에 필요하다.
  .configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
 
  // ENUM 값이 존재하지 않으면 null로 설정한다. Enum 항목이 추가되어도 무시하고 넘어가게 할 때 필요하다.
  .configure(DeserializationFeature.READ_UNKNOWN_ENUM_VALUES_AS_NULL, true);
  // 시간을 timestamp 숫자가 아닌, 문자열로 포맷팅한다. 기본 ISO 포맷
  .configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS, false);

Bidirectional Relation 양방향 관계

Pretty Print

// 전역설정
objectMapper.enable(SerializationFeature.INDENT_OUTPUT);
 
// Writer 당 설정
new ObjectMapper()
.writer()
.withDefaultPrettyPrinter()
.writeValueAsString(객체);

setDateFormat 주의

Hibernate

@JsonRawValue

@JsonInclude

JsonNodeFactory

JsonNodeFactory.instance.objectNode().put("id", 123L)
            .put("name", "JSONNODE")
            .put("age", 12)
            .toString();

Java 8

<dependency>
    <groupId>com.fasterxml.jackson.module</groupId>
    <artifactId>jackson-module-parameter-names</artifactId>
</dependency>
<dependency>
    <groupId>com.fasterxml.jackson.datatype</groupId>
    <artifactId>jackson-datatype-jdk8</artifactId>
</dependency>
<dependency>
    <groupId>com.fasterxml.jackson.datatype</groupId>
    <artifactId>jackson-datatype-jsr310</artifactId>
</dependency>
// Up to Jackson 2.9: (but not with 3.0)
ObjectMapper mapper = new ObjectMapper()
   .registerModule(new ParameterNamesModule())
   .registerModule(new Jdk8Module())
   .registerModule(new JavaTimeModule()); // new module, NOT JSR310Module

Jackson 2.10 부터 ObjectMapper 생성 방식 변경됨

JsonMapper objectMapper = JsonMapper.builder()
    .addModules(new ParameterNamesModule(), new Jdk8Module(), new JavaTimeModule())
    // 모르는 property 를 역직렬화 할 때 오류없이 무시하게 한다.
    .configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false)
    // 모르는 ENUM 값을 역직렬화 할 때 null로 취급하게 한다.
    .configure(DeserializationFeature.READ_UNKNOWN_ENUM_VALUES_AS_NULL, true)
    // 시간 관련 객체(LocalDateTime, java.util.Date)를 직렬화 할 때 timestamp 숫자값이 아닌 포맷팅 문자열로 한다.
    .configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS, false)
    // 숫자를 문자로 직렬화하기, BigDecimal 보호?
    .enable(JsonWriteFeature.WRITE_NUMBERS_AS_STRINGS)
    .defaultTimeZone(TimeZone.getDefault())
    .defaultLocale(Locale.getDefault())
    .build();

Java 16 Record

참고