我们有一个多态的行为,为了迎合反序列化,我们为此编写了一个定制的Moshi适配器。
@JsonClass(generateAdapter = true)
open class Field
@JsonClass(generateAdapter = true)
data class Field1 (
@Json(name = "name")
val name: String
): Field()
@JsonClass(generateAdapter = true)
data class Field2 (
@Json(name = "address")
val address: String
): Field()
以上是我们所做工作的非常简化的版本。我们想将Moshi生成的适配器用于子类(Field1
和Field2
),并且此自定义适配器仅根据可用字段委托fromJson。这是Field
的自定义适配器:
class FieldAdapter {
var moshi = Moshi.Builder().build()
@ToJson
fun toJson(field: Field): String {
return ""
}
@FromJson
fun fromJson(json: String): Field {
val jsonObject = gson.fromJson(json, JsonObject::class.java)
var field: Field? = null
if (jsonObject.has("name")) {
val field1JsonAdapter: JsonAdapter<Field1> = moshi.adapter(Field1::class.java)
field = field1JsonAdapter.fromJson(json)
} else if (jsonObject.has("address")) {
val field2JsonAdapter: JsonAdapter<Field2> = moshi.adapter(Field2::class.java)
field = field2JsonAdapter.fromJson(json)
}
field?.let {
return it
}
throw JsonDataException("Not a valid field JSON")
}
}
以下测试无效:
@Test
fun testField1Serialization() {
val json = MockResponseFileReader("field1.json").content
val moshi = Moshi.Builder().add(FieldAdapter()).build()
val adapter = moshi.adapter(Field::class.java)
val field = adapter.fromJson(json)
val field1 = field as Field1
assertEquals("abc", field1.name)
}
上面的测试没有调用自定义适配器的fromJson,但是,如果我们将val adapter = moshi.adapter(Field::class.java)
更改为val adapter = FieldAdapter()
(以对自定义适配器进行硬编码),它将起作用。
您能指导我们做错了什么吗?
任何帮助将不胜感激。
TIA
答案 0 :(得分:1)
对于面临相同问题的任何人,只需在自定义JSON适配器中实现JsonAdapter
(toJson和fromJson方法),它就可以工作。
不幸的是,我仍然没有答案,为什么原始问题的适配器不起作用,因为这是官方文档中的处理方法。