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

Json parsing with scala/play: how to get a trait?

我在尝试使用 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] 和 "not found: value MyTrait"。然而,这与我对标准 类 所做的完全相同,所以我真的不知道如何进行。

有什么想法吗?我是 Play 的新手(说实话,Scala 也是如此)所以我可能做错了一些非常基本的错误。特别是,我高度怀疑 "map" 调用。

干杯,

Traits 没有 apply 方法,这些通常用于 case 类。 您可以扩展 Reads 特性并实现 reads 方法,如下所示:

implicit val creatureReads = new Reads[MyTrait] {
  override def reads(js: JsValue): JsResult[MyTrait] = {
    JsSuccess(strToObject((js \ "t" ).as[String]))
  }
}

我编辑了对 return JsSuccess 的回答,您可以添加更好的验证来检查是否存在 "t"。

您的代码也应该调用:

val myobject = jsonObject.as[MyTrait]