我使用Jackson将json字符串解析为scala case类实例。 这是我的代码
import com.fasterxml.jackson.databind.{DeserializationFeature, ObjectMapper}
import com.fasterxml.jackson.module.scala.DefaultScalaModule
import scala.reflect.{ClassTag, _}
object JsonUtil {
val jacksonMapper = new ObjectMapper()
jacksonMapper.registerModule(DefaultScalaModule)
jacksonMapper.configure(DeserializationFeature.FAIL_ON_MISSING_CREATOR_PROPERTIES, false)
jacksonMapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false)
def toJson(value: Map[Symbol, Any]): String = {
toJson(value map { case (k,v) => k.name -> v})
}
def toJson(value: Any): String = {
jacksonMapper.writeValueAsString(value)
}
def fromJson[T: ClassTag](json: String): T = {
jacksonMapper.readValue[T](json, classTag[T].runtimeClass.asInstanceOf[Class[T]])
}
}
这是json解析错误
case class Person(name: String, age: Long, score: List[Long])
val person = JsonUtil.fromJson[Person]("""{"name": 123654,"age":23, "score": [6,7,9]}""")
person.name
person.score
person.score.head
res0: String = 123654
java.lang.ClassCastException: java.lang.Integer cannot be cast to java.lang.Long
at scala.runtime.BoxesRunTime.unboxToLong(ws.sc93376:101)
at #worksheet#.#worksheet#(ws.sc93376:35)
我知道杰克逊很聪明,可以在数字类型之间进行转换,字符串转换为数字,反之亦然,但看起来它只适用于非收集情况。
我怎样才能做得更好,强制杰克逊递归转换类型内部集合?
答案 0 :(得分:0)
您必须在score: List[Long]
之前添加此注释:
@JsonDeserialize(contentAs = classOf[java.lang.Long])
来源:https://github.com/FasterXML/jackson-module-scala/wiki/FAQ