新标签请求: java-ee-8
它有一个新的特征,叫做jsonb。使用jsonb,我不能让嵌套序列化工作。见下面粗体印刷。
所以,我写了一个jaxrs应用程序。这个应用程序有一个使用jsonb的消息体编写器:
final JsonbConfig defaultConfig = new JsonbConfig()
.withFormatting(Boolean.TRUE)
.withNullValues(Boolean.TRUE)
.withSerializers(
new QueryParamEntrySerializer(),
new ApiResponseDtoSerializer())
.withAdapters(new ResponseStatusJsonbAdapter());
final Jsonb jsonb = JsonbBuilder.create(defaultConfig);ApiResponseDto如下所示:
@Value.Immutable
@JsonbTypeSerializer(ApiResponseDtoSerializer.class)
public interface ApiResponseDto {
ResponseStatus status();
String message();
Optional<? extends Object> data();
}ResponseStatus是一个enumm,可以通过上面的TypeAdapter进行序列化。在这门课上,我写了ApiResponseDtoSerializer。
@Provider
public class ApiResponseDtoSerializer implements JsonbSerializer<ImmutableApiResponseDto> {
@Override
public void serialize(
final ImmutableApiResponseDto obj,
final JsonGenerator generator,
final SerializationContext ctx) {
generator.writeStartObject();
ctx.serialize("status", obj.status(), generator);
ctx.serialize("data", obj.data(), generator);
ctx.serialize("message", obj.message(), generator);
generator.writeEnd();
}
}现在,可选的data()应该包含如下所示的ImmutableSet of QueryParamEntry:
@Value.Immutable
@JsonbTypeSerializer(ImmutableQueryParamEntrySerializer.class)
public interface QueryParamEntry {
@Value.Parameter
String key();
@Value.Parameter
Optional<String> value();
}类型适配器是这样一个:
@Provider
public class ImmutableQueryParamEntrySerializer implements JsonbSerializer<ImmutableQueryParamEntry> {
private static final Logger LOG = LoggerFactory.getLogger(ImmutableQueryParamEntrySerializer.class);
@Override
public void serialize(
final ImmutableQueryParamEntry obj,
final JsonGenerator generator,
final SerializationContext ctx) {
generator.writeStartObject();
LOG.debug("Writing: key = [{}].", obj.key());
ctx.serialize("key", obj.key(), generator);
ctx.serialize("value", obj.value(), generator);
generator.writeEnd();
}
}最后的产出是:
{
"status": "success",
"data": [
{
"key": null,
"value": null
}
],
"message": "Returning query param values."
}正如您所看到的,嵌套序列化不起作用。 Jsonb似乎找到了正确的类型(否则它根本不会序列化对象)。但是,即使是来自我的SerializerClass的日志语句也从未被调用过。
顺便说一句:您需要番石榴22和immutables.github.io来编译这段代码,而slf4j显然是:
<dependency>
<groupId>org.jboss.resteasy</groupId>
<artifactId>jaxrs-api</artifactId>
<version>3.0.2.Final</version>
<scope>provided</scope>
</dependency>
<!-- JSON-P API -->
<dependency>
<groupId>javax.json</groupId>
<artifactId>javax.json-api</artifactId>
<version>1.1</version>
<scope>provided</scope>
</dependency>
<!-- https://mvnrepository.com/artifact/javax.json.bind/javax.json.bind-api -->
<dependency>
<groupId>javax.json.bind</groupId>
<artifactId>javax.json.bind-api</artifactId>
<version>1.0</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>org.immutables</groupId>
<artifactId>value</artifactId>
</dependency>
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
</dependency>发布于 2018-12-12 10:58:34
所以,这就是让它发挥作用的关键。
我摆脱了定制的序列化器。正如我在评论中提到的,它们在未发布版本1.0.3之前就被破坏了。
相反,将方法重命名为getStatus()、getMessage()和getData() (注意get-Prefix)。对于getData();,只返回一个Optional<Object>,而不是Optional<? extends Object>。否则,不变将拒绝特殊待遇的可选。
在那之后,一切都进行得很顺利。
https://stackoverflow.com/questions/46907006
复制相似问题