我试图使用play2在Scala中读取Json时使用信息创建对象时遇到困难。 这是我现在的代码:
trait MyTrait {
}
object object1 extends MyTrait {
override def toString: String = "object1"
}
object object2 extends MyTrait{
override def toString: String = "object2"
}
def strToObject(str: String): MyTrait = str match {
case "object1" => object1
case "object2" => object2
}
这就是我写Json的方式:
implicit val traitWrites = new Writes[MyTrait] {
def writes(t: MyTrait) = Json.obj(
"t" -> t.toString)
}
输出
println("object1: " + Json.toJson(object1).toString)
println("object2: " + Json.toJson(object1).toString)
object1: {"t":"object1"}
object2: {"t":"object1"}
这就是我尝试阅读的方式,但它不起作用。
implicit val traitReads: Reads[MyTrait] = (
(JsPath \ " t" ).read[String])map(str => strToObject(str)) (MyTrait.apply _)
val jsonObject = Json.parse(Json.toJson(object1).toString)
val aux = jsonObject \ "t"
val myobject = aux.as[MyTrait]
它抱怨(MyTrait.apply _)和[MyTrait]“找不到:值MyTrait”。然而,这与标准类完全相同,所以我真的不知道如何继续。
有什么想法吗?我是Play的新手(和Scala一样,也是如此)所以我可能正在做一些非常基本的错误。特别是,我非常怀疑“地图”电话。
干杯,
答案 0 :(得分:5)
Traits没有apply方法,这些通常与case类一起使用。 您可以扩展Reads特性并实现reads方法,如下所示:
implicit val creatureReads = new Reads[MyTrait] {
override def reads(js: JsValue): JsResult[MyTrait] = {
JsSuccess(strToObject((js \ "t" ).as[String]))
}
}
我编辑了我的答案以返回一个JsSuccess,你可以添加更好的验证来检查是否存在“t”。
您的代码也应该调用:
val myobject = jsonObject.as[MyTrait]