繁体   English   中英

在 Scala/play 中解析“字符串化”JSON

[英]Parsing "stringified" JSON in scala/play

我正在实现一个 Scala/Play API (apiA),它使用一个我无法控制的 API (apiB)。 ApiB 返回一个 JSON 响应,在某些情况下,该响应将 JSON 嵌入到字符串中。 例子:

{
  "name":"some_name",
  "scores": "[[10,15]]",
  "data": "{\"attr1\":\"value1\",\"attr2\":\"value3\"}"
}

ApiA 需要在将所有数据传递给客户端之前访问name的值,并且它应该作为正确的 JSON 提供给客户端。 我正在考虑将原始响应解析为

case class Response(name: String, scores: JsValue, data: JsValue)

或者

case class Response(name: String, scores: Seq[Seq[Int]], data: Map[String, String])

现在,只要不是包含 JSON 的字符串, scoresdata被解析成什么类型​​并不重要。

现在,如果 JSON 响应格式良好,那么写入格式/读取/写入将很简单,但我有点想知道如何在解析为最终类型之前将内容转换为 JSON。

任何帮助,将不胜感激。

case class Response(name: String, scores: Seq[Seq[Int]], data: Map[String, String])

import play.api.libs.json._

val stringified = Reads[JsValue] {
  _.validate[String].flatMap { raw =>
    try {
      JsSuccess(Json.parse(raw))
    } catch {
      case cause =>
        JsError(cause.getMessage)
    }
  }
}

implicit val respReads = Reads[Response] { js =>
  for {
    name <- (js \ "name").validate[String]
    scores <- (js \ "scores").validate(
      stringified).flatMap(_.validate[Seq[Seq[Int]]])
    data <- (js \ "data").validate(
      stringified).flatMap(_.validate[Map[String, String]])
  } yield Response(name, scores, data)
}

Json.parse("""{
  "name":"some_name",
  "scores": "[[10,15]]",
  "data": "{\"attr1\":\"value1\",\"attr2\":\"value3\"}"
}""").validate[Response]
// JsSuccess(Response(some_name,Vector(Vector(10, 15)),Map(attr1 -> value1, attr2 -> value3)),)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM