在把java对象转换为json时,有时需要依据需求动态过滤掉一些属性,比如使用注解形式过滤,这样是静态的。jackjson提供了这种动态过滤的。代码如下
import java.io.Writer;
import org.codehaus.jackson.JsonNode;
import org.codehaus.jackson.map.DeserializationConfig;
import org.codehaus.jackson.map.DeserializationConfig.Feature;
import org.codehaus.jackson.map.ObjectMapper;
import org.codehaus.jackson.map.annotate.JsonSerialize;
import org.codehaus.jackson.map.introspect.AnnotatedClass;
import org.codehaus.jackson.map.introspect.JacksonAnnotationIntrospector;
import org.codehaus.jackson.map.ser.FilterProvider;
import org.codehaus.jackson.map.ser.impl.SimpleBeanPropertyFilter;
import org.codehaus.jackson.map.ser.impl.SimpleFilterProvider;
import org.codehaus.jackson.type.JavaType;
import org.slf4j.Logger;
import com.maowu.commons.logutil.LogProxy;
public class JsonConverter
{
private static final Logger log = LogProxy.getLogger(JsonConverter.class);
public static final ObjectMapper mapper = new ObjectMapper();
static
{
// 序列化时候,只序列化非空字段
mapper.setSerializationConfig(mapper.getSerializationConfig().withSerializationInclusion(
JsonSerialize.Inclusion.NON_NULL));
// 当范序列化出现未定义字段时候,不出现错误
DeserializationConfig deserializationConfig = mapper.getDeserializationConfig();
deserializationConfig = deserializationConfig.without(Feature.FAIL_ON_UNKNOWN_PROPERTIES,
Feature.FAIL_ON_NULL_FOR_PRIMITIVES);
deserializationConfig = deserializationConfig.with(Feature.ACCEPT_EMPTY_STRING_AS_NULL_OBJECT,
Feature.ACCEPT_SINGLE_VALUE_AS_ARRAY);
mapper.setDeserializationConfig(deserializationConfig);
}
public static String format(Object obj)
{
try
{
return mapper.writeValueAsString(obj);
}
catch (Exception e)
{
log.debug("format obj failure.obj=" + obj);
throw new RuntimeException("JsonUtil.format error:" + obj, e);
}
}
public static void outputToWriter(Writer out, Object value)
{
try
{
mapper.writeValue(out, value);
}
catch (Exception e)
{
log.error("JsonUtil.outputToWriter error:" + value, e);
throw new RuntimeException("JsonUtil.outputToWriter error:" + value, e);
}
}
public static <T> T parse(JsonNode body, Class<T> clz)
{
try
{
return mapper.readValue(body, clz);
}
catch (Exception e)
{
log.error("JsonUtil.parse [" + clz + "]:" + body, e);
throw new RuntimeException("JsonUtil.parse [" + clz + "]:" + body, e);
}
}
public static <T> T parse(String str, Class<T> clz)
{
try
{
return mapper.readValue(str == null ? "{}" : str, clz);
}
catch (Exception e)
{
log.error("JsonUtil.parse [" + clz + "]:" + str, e);
throw new RuntimeException("JsonUtil.parse [" + clz + "]:" + str, e);
}
}
public static <T> T parseList(String str, Class<?> clz, Class<?> type)
{
try
{
JavaType javaType = mapper.getTypeFactory().constructParametricType(clz, type);
return mapper.readValue(str, javaType);
}
catch (Exception e)
{
log.error("JsonUtil.parse [" + clz + "]:" + str, e);
throw new RuntimeException("JsonUtil.parse [" + clz + "]:" + str, e);
}
}
public static JsonNode tree(Object obj)
{
try
{
return mapper.valueToTree(obj);
}
catch (Exception e)
{
log.debug("format obj failure.obj=" + obj);
throw new RuntimeException("JsonUtil.format error:" + obj, e);
}
}
public static String serializeAllExcept(Object obj, String... filterFields)
{
try
{
ObjectMapper mapper = new ObjectMapper();
mapper.setSerializationConfig(mapper.getSerializationConfig().withSerializationInclusion(
JsonSerialize.Inclusion.NON_NULL));
FilterProvider filters = new SimpleFilterProvider().addFilter(obj.getClass().getName(),
SimpleBeanPropertyFilter.serializeAllExcept(filterFields));
mapper.setFilters(filters);
mapper.setAnnotationIntrospector(new JacksonAnnotationIntrospector()
{
@Override
public Object findFilterId(AnnotatedClass ac)
{
return ac.getName();
}
});
return mapper.writeValueAsString(obj);
}
catch (Exception e)
{
log.debug("format obj failure.obj=" + obj);
throw new RuntimeException("Json.format error:" + obj, e);
}
}
public static String filterOutAllExcept(Object obj, String... filterFields)
{
try
{
ObjectMapper mapper = new ObjectMapper();
mapper.setSerializationConfig(mapper.getSerializationConfig().withSerializationInclusion(
JsonSerialize.Inclusion.NON_NULL));
FilterProvider filters = new SimpleFilterProvider().addFilter(obj.getClass().getName(),
SimpleBeanPropertyFilter.filterOutAllExcept(filterFields));
mapper.setFilters(filters);
mapper.setAnnotationIntrospector(new JacksonAnnotationIntrospector()
{
@Override
public Object findFilterId(AnnotatedClass ac)
{
return ac.getName();
}
});
return mapper.writeValueAsString(obj);
}
catch (Exception e)
{
log.debug("format obj failure.obj=" + obj);
throw new RuntimeException("Json.format error:" + obj, e);
}
}
}
相关推荐
jackson工具类有动态属性过虑功能.在业务应用中经常会有指定属性序列化json的需求,
Jackson动态属性过滤器-Spring Boot Starter 用于Spring Boot Starter,它提供了一种简便的方法,可以通过动态确定过滤,而无需直接在Java对象上编写注释,并且还可以与Spring MVC / Spring Boot很好地集成。 先决...
杰克逊动态属性过滤器基本上,当您使用Gson时,需要从目标对象上的序列化WITHOUT批注中排除特定字段,您将使用ExclusionStrategy 。 但是我在杰克逊没有找到类似的方法来做到这一点。 因此,此存储库提供了一种动态...
我们的POJO使用@JsonView注解属性传递已经定义的视图。在Spring的Controller我们可以使用Jackson的@JsonView注解我们的方法。序列化Http响应体的时候,JSON响应将在配置视图的基础上进行过滤。我们也可以在Spring ...
杰克逊·贾克斯(Jackson-Jaxrs)属性过滤 概述 用于启用自动过滤来自JAX-RS端点的JSON响应的库。 客户端通过查询参数指定他们想要的属性,并且库负责将响应实体过滤为仅这些属性(请参见的示例)。 经过Jersey测试...
spring-mvc-Json动态忽略目的 : 有时,过滤序列化到 HTTP 响应主体的上下文对象会很有用。在某些情况下,返回的部分数据可能对使用 API 的设备没有用,或者应该对公众保持不可见,因此不应该t 通过 JSON 序列化和...
27.1.Jackson 27.2.GSON 27.3.JSON-B 28.开发Web应用程序 28.1.“Spring Web MVC框架” 28.1.1.Spring MVC自动配置 28.1.2.HttpMessageConverters 28.1.3.自定义JSON序列化程序和反序列化程序 ...
10.4Jackson 支持 96 第三部分 测试 97 11.测试方法安全性 97 11.1安全测试设置 98 11.2 @WithMockUser 98 11.3 @WithAnonymousUser 100 11.4 @用户详细信息 101 11.5 @WithSecurityContext 102 11.6测试元注释 104 ...
6个目标文件,EJB来模拟银行ATM机的流程及操作:获取系统属性,初始化JNDI,取得Home对象的引用,创建EJB对象,并将当前的计数器初始化,调用每一个EJB对象的count()方法,保证Bean正常被激活和钝化,EJB对象是用...
6个目标文件,EJB来模拟银行ATM机的流程及操作:获取系统属性,初始化JNDI,取得Home对象的引用,创建EJB对象,并将当前的计数器初始化,调用每一个EJB对象的count()方法,保证Bean正常被激活和钝化,EJB对象是用...