@SerializedName
Gson의 필드에 여러 주석을 정의하는 것은 지원되지 않습니다 .
이유 : 기본적으로 Deserialization은 LinkedHashMap으로 관리되며 키는 들어오는 json의 필드 이름 (사용자 정의 클래스의 필드 이름 또는 serializedNames가 아님)으로 정의되며 일대일 매핑이 있습니다. 당신은 구현 (방법 직렬화 작품) 볼 수있는 ReflectiveTypeAdapterFactory
클래스의 내부 클래스 Adapter<T>
의 read(JsonReader in)
방법을.
해결 방법 :
사용자 지정 쓸 수 TypeAdapter 있는 핸들 name
, person
및 user
JSON 태그 및 사용자 정의 클래스의 이름 필드에 매핑 MyClass
:
class MyClassTypeAdapter extends TypeAdapter<MyClass> {
@Override
public MyClass read(final JsonReader in) throws IOException {
final MyClass myClassInstance = new MyClass();
in.beginObject();
while (in.hasNext()) {
String jsonTag = in.nextName();
if ("id".equals(jsonTag)) {
myClassInstance.id = in.nextInt();
} else if ("name".equals(jsonTag)
|| "person".equals(jsonTag)
|| "user".equals(jsonTag)) {
myClassInstance.name = in.nextString();
}
}
in.endObject();
return myClassInstance;
}
@Override
public void write(final JsonWriter out, final MyClass myClassInstance)
throws IOException {
out.beginObject();
out.name("id").value(myClassInstance.id);
out.name("name").value(myClassInstance.name);
out.endObject();
}
}
테스트 케이스 :
String jsonVal0 = "{\"id\": 5382, \"user\": \"Mary\" }";
String jsonVal1 = "{\"id\": 2341, \"person\": \"Bob\"}";
final GsonBuilder gsonBuilder = new GsonBuilder();
gsonBuilder.registerTypeAdapter(MyClass.class, new MyClassTypeAdapter());
final Gson gson = gsonBuilder.create();
MyClass myClassInstance0 = gson.fromJson(jsonVal0, MyClass.class);
MyClass myClassInstance1 = gson.fromJson(jsonVal1, MyClass.class);
System.out.println("jsonVal0 :" + gson.toJson(myClassInstance0));
// output: jsonVal0 :{"id":5382,"name":"Mary"}
System.out.println("jsonVal1 :" + gson.toJson(myClassInstance1));
// output: jsonVal1 :{"id":2341,"name":"Bob"}
TypeAdapters에 대한 예.
편집 2016.04.06 : @Mathieu Castets가 답변을 작성 했으므로 현재 지원됩니다. (이 질문에 대한 정답입니다.)
public abstract String [] alternate
반환
값 : 역 직렬화 될 때 필드의 대체 이름 기본값 : {}