过滤掉与杰克逊性能过滤性能是非常简单的:球衣/杰克逊 - 基于查询参数
final FilterProvider filters = new SimpleFilterProvider().
addFilter(... the name of the filter ...,
SimpleBeanPropertyFilter.filterOutAllExcept(... enumeration of properties ...));
<object mapper>.writer(filters).writeValueAsString(... the bean ...);
我想这在我州的REST应用程序集成。 API用户可以通过提供查询字符串来过滤属性:
https://the-api/persons?fields=name,age,location,gender
什么是泽西岛最优雅的方式?我可以很容易地在我的资源方法中执行上述操作,但这不知怎的会杀死泽西岛的优雅。另外,我相信为每个请求创建一个新的ObjectMapper都会有性能损失。
可以写一个MessageBodyWriter
,其取出由UriInfo
上下文fields
查询参数和序列化,同时施加一个滤波器基于所述fields
查询参数JSON的实体。这是做这件事的最好方法吗?像这样:
@Provider
@Produces(MediaType.APPLICATION_JSON)
public class JustTesting implements MessageBodyWriter<Object> {
@Context
UriInfo uriInfo;
@Context
JacksonJsonProvider jsonProvider;
public boolean isWriteable(Class<?> aClass, Type type, Annotation[] annotations, MediaType mediaType) {
return MediaType.APPLICATION_JSON_TYPE.equals(mediaType);
}
public long getSize(Object object, Class<?> aClass, Type type, Annotation[] annotations, MediaType mediaType) {
return -1;
}
public void writeTo(Object object, Class<?> aClass, Type type, Annotation[] annotations, MediaType mediaType, MultivaluedMap<String, Object> stringObjectMultivaluedMap, OutputStream outputStream) throws IOException, WebApplicationException {
final FilterProvider filters = new SimpleFilterProvider().addFilter("MyFilter", SimpleBeanPropertyFilter.filterOutAllExcept(uriInfo.getQueryParameters().getFirst("fields")));
jsonProvider.locateMapper(aClass, mediaType).writer(filters).writeValue(outputStream, object);
}
}
它似乎工作,但我不确定这样做是否聪明。我是泽西图书馆的新手。
我正在处理类似的事情。我的解决方案实际上也涉及Orika(我想保存查找lazey集合)。因此,我实现了一个管理器,用于检查字段上的自定义注释(如@Basic)以确定它们是否可映射,以及是否应该对其进行过滤。 更具体地说,在泽西岛一侧,我正在尝试使用com.fasterxml.jackson.jaxrs.cfg.ObjectWriterInjector来将我“MixedIn”的过滤器应用于Object.class。 – 2014-10-21 05:29:41