我使用内置的jerson与playframework 2,和所有我想要的是序列化映射,包含不同类型的值:Jerkson。序列化映射到JsValue
object AppWriter extends Writes[Application] {
def writes(app: Application): JsValue = {
Json.toJson(Map(
"id" -> app.getId.toString,
"name" -> app.getName,
"users" -> Seq(1, 2, 3)
))
}
}
在这种情况下,我有:
No Json deserializer found for type scala.collection.immutable.Map[java.lang.String,java.lang.Object].
Try to implement an implicit Writes or Format for this type
通过框架代码Navigatin显示有地图[字符串,V]类型的序列化程序隐式def mapWrites [V] ..,但我不明白为什么它不适用。
任何人都可以帮助我吗?
UPD:我找到简单的解决方法:
object AppWriter extends Writes[Application] {
def writes(app: Application): JsValue = {
Json.toJson(Map[String, JsValue](
"id" -> JsNumber(BigDecimal(app.getId)),
"name" -> JsString(app.getName),
"users" -> JsArray(Seq(1, 2, 3).map(x => JsNumber(x)))
))
}
}
,但事实并非如此优雅...
你为什么要在这样的地图中存储数据?地图通常是一个关键值存储区,其中所有值的类型都是相同的。您应该只使用一个案例类来为这些数据建模。 –
@ DominicBou-Samra,想法听起来不错,但看起来像没有从case class,string only生成JsValue的方法。 –