使用json播放处理null

问题描述 投票:0回答:1

我正在尝试使用Play库为某些字段解析具有空值的json。有一个代表数据的案例类:

case class Id(value: Int) extends AnyVal

case class Name(value: String) extends AnyVal

case class Number(value: Int) extends AnyVal

case class Data(id: Option[Id], name: Option[Name], number: Option[Number])

这里是当前解析的工作方式:

def parse(jsValue: JsValue): Try[Seq[Data]] = Try {
    jsValue.as[JsArray].value
      .flatMap { record =>
        val id = Id((record \ "id").as[Int])
        val name = Name((record \ "name").as[String])
        val number = Number((record \ "number").as[Int])

        Some(Data(Some(id), Some(name), Some(number)))
      }
  }

使用特定数据类型进行解析无法处理空值,因此此实现返回:

Failure(play.api.libs.json.JsResultException: JsResultException(errors:List((,List(JsonValidationError(List(error.expected.jsstring),WrappedArray()))))))

对于这样的输入数据:

{
    "id": 1248,
    "default": false,
    "name": null,
    "number": 2
  }

我想要这样的东西:Seq(Data(Some(Id(1248)), None, Some(Number(2))))

我将把数据写到数据库中,所以我不介意为这些字段写一些空值。

如何处理已解析的json中字段的空值?

json scala playframework
1个回答
0
投票

如果您没有被锁定使用play-json,那么让我展示一下如何使用jsoniter-scala轻松完成它:

import com.github.plokhotnyuk.jsoniter_scala.core._
import com.github.plokhotnyuk.jsoniter_scala.macros._

implicit val codec: JsonValueCodec[Seq[Data]] = JsonCodecMaker.make(CodecMakerConfig)

val json: Array[Byte] = """[
  {
    "id": 1248,
    "default": false,
    "name": null,
    "number": 2
  }
]""".getBytes("UTF-8")
val data: Seq[Data] = readFromArray(json)
println(data)

将产生以下输出:

List(Data(Some(Id(1248)),None,Some(Number(2))))

Here,您可以看到一个示例如何将其与Play框架集成。

© www.soinside.com 2019 - 2024. All rights reserved.