17

我正在使用 Jackson 1.6.4 和 Java JDK 6。

我不想使用 Jackson 注释;我想要没有设置器的不可变 Java 对象。

这两个要求似乎有冲突。

如果我添加私有设置器反序列化工作正常。

我试图不为我的不可变对象求助于私人二传手——我很固执。

我正在尝试自定义实现 VisibilityChecker 以允许任何字段访问。

但是,如果有人有一些建议或经验教训,他们可以分享,我将不胜感激。

更新:它正在工作。

构建器模式,私有构造器 - 一个 la Bloch “Effective Java”。

它需要设置反序列化配置和可见性,但现在可以开始了。

public class JsonMapper
{
   private static final int INITIAL_SIZE = 2048;
   /** See http://wiki.fasterxml.com/JacksonBestPracticeThreadSafety?highlight=(\bCategoryJackson\b) */
   private static ObjectMapper mapper;

   static
   {
      mapper = new ObjectMapper();

      mapper.configure(SerializationConfig.Feature.WRITE_DATES_AS_TIMESTAMPS, false);
      SerializationConfig serializationConfig = mapper.getSerializationConfig();
      serializationConfig.setDateFormat(Person.DEFAULT_FORMATTER);

      mapper.configure(DeserializationConfig.Feature.FAIL_ON_UNKNOWN_PROPERTIES,false);
      DeserializationConfig deserializationConfig = mapper.getDeserializationConfig();
      deserializationConfig.setDateFormat(Person.DEFAULT_FORMATTER);
      deserializationConfig.enable(DeserializationConfig.Feature.AUTO_DETECT_FIELDS);
      mapper.setVisibilityChecker(VisibilityChecker.Std.defaultInstance().withFieldVisibility(JsonAutoDetect.Visibility.ANY));
   }

   public static <T> String serialize(T o) throws IOException
   {
      StringWriter sw = new StringWriter(INITIAL_SIZE);
      mapper.writeValue(sw, o);

      return sw.toString();
   }

   public static <T> T deserialize(String source, Class<T> targetClass) throws IOException
   {
      ByteArrayInputStream stream = new ByteArrayInputStream(source.getBytes());
      TreeTraversingParser treeTraversingParser = new TreeTraversingParser(mapper.readTree(stream));
      treeTraversingParser.setCodec(mapper);

      return treeTraversingParser.readValueAs(targetClass);
   }
}
4

1 回答 1

18

很高兴听到你让它工作——改变自动检测可见性级别的能力是一个非常强大的功能,但是有这么多的功能,找到所有的功能并不是一件容易的事。

几个额外的提示:如果你不想在 POJO 中添加 Jackson 注释,你仍然可以使用mix-in annotations。有了这个,您可以使用@JsonCreator 指定要使用的非默认构造函数,它允许真正的不可变值类型(更多关于杰克逊和本文不可变类型的信息)。

最后:虽然尚未直接支持构建器模式,但已根据此 Jira 条目进行了计划。

于 2011-01-28T05:35:47.877 回答