json4s:无法解析JSON与重命名字段

问题描述:

我需要序列化,然后反序列化案例类对象与字段"name"从JSON,它有"animalname"字段而不是"name"。序列化工作正常,但反序列化没有。我用FieldSerializer与renameTo()renameFrom()json4s:无法解析JSON与重命名字段

import org.json4s._ 
import org.json4s.FieldSerializer._ 
import org.json4s.jackson.Serialization._ 

case class WildDog(name: String) 
val dogSerializer = FieldSerializer[WildDog](
    renameTo("name", "animalname"), 
    renameFrom("animalname", "name")) 
implicit val formats = DefaultFormats + dogSerializer 
// serialize 
val json = write(WildDog("beefy")) // {"animalname":"beefy"}, as expected 
// try to deserialize 
val dog = parse(json).extract[WildDog] // expected: Dog("beefy") 

其实,提取物()抛出异常:

org.json4s.package$MappingException: No usable value for name 
Did not find value which can be converted into java.lang.String 
    at org.json4s.reflect.package$.fail(ws.sc:94) 
    at org.json4s.Extraction$ClassInstanceBuilder.org$json4s$Extraction$ClassInstanceBuilder$$buildCtorArg(ws.sc:409) 
    at org.json4s.Extraction$ClassInstanceBuilder$$anonfun$11.apply(ws.sc:417) 
    at org.json4s.Extraction$ClassInstanceBuilder$$anonfun$11.apply(ws.sc:417) 
    at scala.collection.TraversableLike$$anonfun$map$1.apply(ws.sc:240) 
    at scala.collection.TraversableLike$$anonfun$map$1.apply(ws.sc:240) 
    at scala.collection.mutable.ResizableArray$class.foreach(ws.sc:55) 
    at scala.collection.mutable.ArrayBuffer.foreach(ws.sc:43) 
    at scala.collection.TraversableLike$class.map(ws.sc:240) 
    at scala.collection.AbstractTraversable.map(ws.sc:101) 
    at org.json4s.Extraction$ClassInstanceBuilder.org$json4s$Extraction$ClassInstanceBuilder$$instantiate(ws.sc:417) 
    at org.json4s.Extraction$ClassInstanceBuilder$$anonfun$result$6.apply(ws.sc:445) 
    at org.json4s.Extraction$ClassInstanceBuilder$$anonfun$result$6.apply(ws.sc:442) 
    at org.json4s.Extraction$.org$json4s$Extraction$$customOrElse(ws.sc:454) 
    at org.json4s.Extraction$ClassInstanceBuilder.result(ws.sc:442) 
    at org.json4s.Extraction$.extract(ws.sc:304) 
    at org.json4s.Extraction$.extract(ws.sc:38) 
    at org.json4s.ExtractableJsonAstNode.extract(ws.sc:17) 

如何正确地反序列化JSON这样?

更新:我使用Scala 2.10,json4s 3.2.5。

更新2:我用这个Maven的依赖于json4s:

<dependency> 
    <groupId>org.json4s</groupId> 
    <artifactId>json4s-jackson_2.10</artifactId> 
    <version>3.2.5</version> 
</dependency> 

尝试val dog = read[WildDog](json)代替val dog = parse(json).extract[WildDog]

GitHub的页面 - https://github.com/json4s/json4s有其他一些很好的例子太多。

编辑:

工作版本:
的Scala 2.10 & & org.json4s.jackson> = 3.5.0
的Scala 2.11 & & org.json4s.jackson> = 3.2.5

我还没有检查早期版本的Scala 2.10,但是当我使用3.2.5时存在异常。

另外,我能得到val dog = parse(json).extract[WildDog]工作,但你必须导入JsonMethods - >import org.json4s.jackson.JsonMethods.parse

+0

试过,同样MappingException :( –

+1

版本您正在使用什么斯卡拉我能得到它一起工作? 2.11而不是2.10 – pjames

+0

我使用Scala 2.10,json4s 3.2.5。我想,我现在不会有机会切换到2.11 ... –