FieldNaming 정책 JSON 필드 이름에 대한 몇 가지 표준 명명 규칙을 정의하는 데 사용할 수 있으며 GsonBuilder 와 함께 사용할 수 있습니다. Gson 구성 인스턴스 Java 필드 이름을 원하는 JSON 필드 이름으로 올바르게 변환합니다. setFieldNamingPolicy() 를 사용할 수 있습니다. GsonBuilder 메소드 직렬화 동안 개체의 필드에 대한 특정 명명 정책 전략을 구성하기 위해 및 역직렬화 .
Gson은 다음과 같은 필드 이름 지정 정책을 통해 다양한 필드 이름 지정 요구 사항을 지원합니다.
- FieldNamingPolicy.IDENTITY :객체를 직렬화할 때 자바 모델과 똑같은 이름을 사용합니다.
- FieldNamingPolicy.LOWER_CASE_WITH_UNDERSCORES :Java 필드 이름을 카멜 케이스 형식에서 각 단어가 밑줄(_)로 구분되는 소문자 필드 이름으로 수정합니다.
- FieldNamingPolicy.LOWER_CASE_WITH_DASHES: Java 필드 이름을 낙타 형식에서 대시(-)로 구분된 소문자 필드 이름으로 수정합니다.
- FieldNamingPolicy.UPPER_CAMEL_CASE :JSON 형식으로 직렬화할 때 Java 필드 이름의 첫 번째 "문자"가 대문자인지 확인합니다.
- FieldNamingPolicy.UPPER_CAMEL_CASE_WITH_SPACES :JSON 형식으로 직렬화할 때 Java 필드 이름의 첫 번째 "문자"가 대문자인지 확인하고 단어는 공백으로 구분됩니다.
예시
import com.google.gson.*; import java.sql.Date; import java.time.LocalDate; public class FieldNamingPolicyTest { public static void main(String[] args) { Gson gson = new GsonBuilder().setPrettyPrinting().setDateFormat("yyyy-MM- dd") .setFieldNamingPolicy(FieldNamingPolicy.LOWER_CASE_WITH_DASHES).create(); Person p = new Person("Raja", "Ramesh", 30, Date.valueOf(LocalDate.of(1988, 1, 1))); String jsonStr = gson.toJson(p); System.out.println(jsonStr); } } // Person class class Person { private String fistName; private String lastName; private int _age; private Date dateOfBirth; public Person(String fistName, String lastName, int _age, Date dateOfBirth) { super(); this.fistName = fistName; this.lastName = lastName; this._age = _age; this.dateOfBirth = dateOfBirth; } }
출력
{ "fist-name": "Raja", "last-name": "Ramesh", "_age": 30, "date-of-birth": "1988-01-01" }