在这种情况下,播放 json 看起来效果不佳



我有以下代码来处理播放 json

import play.api.libs.json.json

trait A {
def x: Option[Int]
def y: Option[String]
}
case class A1(x: Option[Int] = Some(1), y: Option[String]) extends A
object PlayJsonBug {
def main(args: Array[String]): Unit = {
implicit val A1Reader = Json.reads[A1]
implicit val A1Writer = Json.writes[A1]
val str = """{"y":"xyz"}"""
val a: A1 = Json.fromJson[A1](Json.parse(str)).get
println(a)
}

}

案例类 A1 具有x的默认值,即Some (1)。 当我解析{"y":"xyz"}时,结果是A1(None,Some(xyz)),我认为这里应该使用默认值,即tis,结果应该是A1(Some(1),Some(xyz))

这是一个错误吗?或者我如何解决这个问题

>Json.reads是一个 scala 宏,它的实现不关心默认值,因为它只遍历所有类的 case 访问器。您需要实现自己的play.api.libs.json.Reads以支持回退到默认参数,以防在 json 中找不到值。

它可能看起来像这样(对于Play 2.5.x(:

implicit object A1Reads extends Reads[A1] {
private val generatedReads = Json.reads[A1]
override def reads(json: JsValue): JsResult[A1] = {
// re-use reads, but replace None for x with default param
generatedReads.reads(json).map {
case A1(None, y) => A1(Some(1), y)
case valid => valid
}
}
}

最新更新