我只想为要进行PUT的JSON正文中的一个属性序列化null。我不想为对象中的任何其他类型序列化null。模型类就是这样
@Parcel
class User @ParcelConstructor constructor(var college: College?,
var firstname: String?,
var lastname: String?,
var email: String?,
var active: Boolean = true,
var updatedAt: String?,
var gender: String?,
var picture: String?,
var id: String?,
@field: [CollegeField] var collegeInput: String?,
@field: [CollegeField] var otherCollege: String?,)
如果它们中的任何一个为null,我只想序列化CollegeInput和otherCollege字段。例如
val user = User(firstname = "foo", lastname=null, collegeInput="abcd", otherCollege = null)
Json看起来像这样:
{"user":{
"firstname": "foo",
"collegeInput": "abcd",
"otherCollege": null
}}
otherCollege为null的情况下,对象将省略姓氏,因为默认情况下,moshi不会序列化我想要的null,但是应将qualifer字段序列化为null值
我尝试使用
class UserAdapter {
@FromJson
@CollegeField
@Throws(Exception::class)
fun fromJson(reader: JsonReader): String? {
return when (reader.peek()) {
JsonReader.Token.NULL ->
reader.nextNull()
JsonReader.Token.STRING -> reader.nextString()
else -> {
reader.skipValue() // or throw
null
}
}
}
@ToJson
@Throws(IOException::class)
fun toJson(@CollegeField b: String?): String? {
return b
}
@Retention(AnnotationRetention.RUNTIME)
@JsonQualifier
annotation class CollegeField
我将适配器添加到了moshi,但是它从未被调用
@Provides
@Singleton
fun provideMoshi(): Moshi {
return Moshi.Builder()
.add(UserAdapter())
.build()
}
@Provides
@Singleton
fun provideRetrofit(client: OkHttpClient, moshi: Moshi, apiConfig: ApiConfig): Retrofit {
return Retrofit.Builder()
.baseUrl(apiConfig.baseUrl)
.client(client)
.addCallAdapterFactory(RxJava2CallAdapterFactory.create())
.addConverterFactory(ScalarsConverterFactory.create())
.addConverterFactory(MoshiConverterFactory.create(moshi))
.build()
}
答案 0 :(得分:1)
当限定的字符串值为null时,您的toJson适配器方法将返回null,并且JsonWriter不会写入该null值。
这里是要安装的限定符和适配器工厂。
@Retention(RUNTIME)
@JsonQualifier
public @interface SerializeNulls {
JsonAdapter.Factory JSON_ADAPTER_FACTORY = new JsonAdapter.Factory() {
@Nullable @Override
public JsonAdapter<?> create(Type type, Set<? extends Annotation> annotations, Moshi moshi) {
Set<? extends Annotation> nextAnnotations =
Types.nextAnnotations(annotations, SerializeNulls.class);
if (nextAnnotations == null) {
return null;
}
return moshi.nextAdapter(this, type, nextAnnotations).serializeNulls();
}
};
}
现在,以下将通过。
class User(
var firstname: String?,
var lastname: String?,
@SerializeNulls var collegeInput: String?,
@SerializeNulls var otherCollege: String?
)
@Test fun serializeNullsQualifier() {
val moshi = Moshi.Builder()
.add(SerializeNulls.JSON_ADAPTER_FACTORY)
.add(KotlinJsonAdapterFactory())
.build()
val userAdapter = moshi.adapter(User::class.java)
val user = User(
firstname = "foo",
lastname = null,
collegeInput = "abcd",
otherCollege = null
)
assertThat(
userAdapter.toJson(user)
).isEqualTo(
"""{"firstname":"foo","collegeInput":"abcd","otherCollege":null}"""
)
}
请注意,您应使用Kotlin support in Moshi来避免出现@field:
怪异之处。
答案 1 :(得分:0)
尝试我的要旨:
https://127.0.0.1:8443/account/#
就我而言,我将JSON的NULL转换为默认的double / integer值。您可以轻松修改方法,使其适合您的特定情况。
p.s。其JAVA,请先将其转换为Kotlin。