Json用scala / play解析:如何获得特征?

时间:2017-12-15 16:14:49

标签: json scala playframework-2.0

我试图使用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一样,也是如此)所以我可能正在做一些非常基本的错误。特别是,我非常怀疑“地图”电话。

干杯,

1 个答案:

答案 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]