@SerializedName
Gsonでフィールドに複数の注釈を定義することはサポートされていません。
理由: デフォルトでは、逆シリアル化はLinkedHashMapで管理され、キーは受信したjsonのフィールド名(カスタムクラスのフィールド名やserializedNamesではない)によって定義され、1対1のマッピングがあります。ReflectiveTypeAdapterFactory
クラスの内部クラスAdapter<T>
のread(JsonReader in)
メソッドで実装(逆シリアル化のしくみ)を確認できます。
解決策:、およびjsonタグを処理し、それらをカスタムクラスの名前フィールドにマップする
カスタムTypeAdapterを記述できます。name
person
user
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
戻り値:逆シリアル化されたときのフィールドの代替名
デフォルト: {}