当前位置: 首页 > 知识库问答 >
问题:

使用Jackson从JSON反序列化Scala映射字段

岳阳文
2023-03-14
val mapper = new ObjectMapper() with ScalaObjectMapper
mapper.registerModule(DefaultScalaModule)
@JsonInclude(JsonInclude.Include.NON_DEFAULT)
class MyClass extends Serializable {
  @JsonDeserialize(
    as = classOf[mutable.HashMap[String, Long]],
    keyAs = classOf[java.lang.String],
    contentAs = classOf[java.lang.Long]
  )
  val counts = mutable.Map.empty[String, Long]
}

如果我给它一些JSON,比如:

{"counts":{"foo":1,"bar":2}}

并使用mapper.readvalue[MyClass](jsonString)读取

我得到一个类似unrecognizedPropertyException的异常:未识别的字段“foo”(类mutable.hashmap),未标记为可忽略的

共有1个答案

督建柏
2023-03-14

我做了一个简单的测试,如下所示:

case class TestClass (counts: mutable.HashMap[String, Long])

我把它转换成:

val objectMapper = new ObjectMapper() with ScalaObjectMapper
objectMapper.registerModule(DefaultScalaModule)

val r3 = objectMapper.readValue("{\"counts\":{\"foo\":1,\"bar\":2}}", classOf[TestClass])

显然对我有用。也许是关于Jackson或Scala的版本。例如,你试过杰克逊的不同版本吗?

 类似资料:
  • 如何将jackson JSON映射器与Java 8 LocalDateTime一起使用? JSONMappingException:无法从JSON字符串实例化类型[simple type,class java.time.LocalDateTime]的值;没有单字符串构造函数/工厂方法(通过引用链:mydto[“field1”]->subdto[“date”])

  • 我对Jackson有一个错误的理解,就是将json文件反序列化为poco。这是我的代码: 我的POCO命名为AnimalBean: }还有我的JSON文件: } 当我执行我的代码时,我有以下错误:未识别的字段“动物园”(类动画豆),未标记为可忽略的。我知道问题是我的json文件开始不直接由动物,但我不能改变它,因为它不是我的。我已经尝试把对象apper.configure(Deseriazatio

  • 可以序列化/反序列化< code >映射吗 在这种特殊情况下,我知道总是,和 - 第三方类(我有序列化器和反序列化器),其他值是盒装原语。 有可能和杰克逊做这样的事吗?使用MapSerializer/MapDeserializer可以做到这一点吗?(我找不到任何例子)

  • 我刚刚开始尝试Scala,并尝试在现有的Java/Spring应用程序中使用Jackson2.3.1和Jackson-module-scala。 我试图将JSON反序列化,如下面所示,以到对象的结束,但当我运行下面的代码时,我以到结束: 为什么结果地图的值是另一个地图而不是颜色对象? 是一个具有注释构造函数的现有Java类。 将上述JSON传递给这段代码的输出如下:

  • 假设您有一个JSON,它看起来像这样: 使用Scala和类型来表示这一点似乎很自然: 我的问题是:是否可以使用Jackson的Scala模块将上面的JSON序列化为一个? 我的尝试: 例外情况: 线程“main”com.fasterxml.jackson.databind.JsonMappingExctive中的异常:无法构造...项目的实例,问题:抽象类型需要映射到具体类型,具有自定义反序列化器