在Jersey
的端点我想返回相同的DTO
,但通过使用不同的序列化器将其序列化:需要不同的Date
格式。
public class Foo {
private Date foo;
public Foo() {
this.foo = new Date();
}
public Date getFoo() {
return foo;
}
public void setFoo(Date foo){
this.foo = foo;
}
}
public class MyEndpointsUnix {
@GET
@Path("/dateAsUnix")
public Foo getDateAsUnix() {
return new Foo();
}
}
public class MyEndpointsUTC {
@GET
@Path("/dateAsUTC")
public Foo getdateAsUTC() {
return new Foo();
}
}
我想应该可以手动更改串行器以进行响应。
从OOP
的角度来看,我们可以为各种view
创建新类:
class UnixFoo extends Foo {
private Foo foo;
public UnixFoo(Foo foo) {
this.foo = foo;
}
@JsonFormat(pattern = "yyyy-MM-dd")
@Override
public Date getFoo() {
return foo.getFoo();
}
// other getters
}
在我们的控制器中,我们可以:
public class MyEndpointsUnix {
@GET
@Path("/dateAsUnix")
public Foo getDateAsUnix() {
return new UnixFoo(new Foo());
}
}
当然,这个解决方案有一个缺点,我们需要复制我们的DTO
类。为了避免这种情况,我们可以使用Jackson MixIn Annotation。为此,我们应该创建新的界面:
interface UnixFooMixIn {
@JsonFormat(pattern = "yyyy-MM-dd")
Date getFoo();
}
并用它来丰富ObjectMapper
:
public class MyEndpointsUnix {
@GET
@Path("/dateAsUnix")
public String getDateAsUnix() {
ObjectMapper mapper = new ObjectMapper();
mapper.enable(SerializationFeature.INDENT_OUTPUT);
mapper.addMixIn(Foo.class, UtcFooMixIn.class);
return mapper.writeValueAsString(new Foo());
}
}
在这种情况下,我们需要更改方法签名并返回String
。我们也可以创建一次ObjectMapper
并将其用作单身人士。对于每种view
,我们需要定义新的interface
和新的ObjectMapper
实例。