0

我知道如何使用 play json 库为 play 应用程序进行 json 解析。例如我有以下代码:

class PersonController extends Controller {
    case class Person(age: Int, name: String)
    implicit val personReads = Json.reads[Person]
    implicit val personWrites = Json.writes[Person]

    def create = Action(parse.json) { implicit request =>
        rs.body.validate[Person] match {
            case s: JsSuccess => ...
            case e: JsError => ...
        }
    }
}

我应该如何使用 Argonaut 而不是 Play json 编写像 Reads and Writes 这样的代码?

4

2 回答 2

0

可能这就是你要找的吗?

class PersonController extends Controller {

  case class Person(age: Int, name: String)

  implicit val PersonCodecJson: CodecJson[Person] =
    casecodec2(Person.apply, Person.unapply)("age", "name")

  val argonautParser = new BodyParser[Person] {
    override def apply(v1: RequestHeader): Iteratee[Array[Byte], Either[Result, Person]] =
  }

  def argonautParser[T]()(implicit decodeJson: DecodeJson[T]) = parse.text map { body =>
    Parse.decodeOption[T](body)
  }

  def create = Action(argonautParser) { implicit request =>
    Ok(request.body.name) //request.body is the decoded value of type Person
  }

}

实际上,您需要一个使用 argonaut 而不是播放 json 来解析请求正文的正文解析器。希望这可以帮助。

于 2015-12-18T20:16:24.270 回答
0

argonaut的文档在这方面相当全面。你需要生成一个Codecwith

implicit def PersonCodecJson: CodecJson[Person] =
    casecodec2(Person.apply, Person.unapply)("age", "name")

然后decodeValidation用来取回一个Validation对象。

val result2: Validation[String, Person] =
    Parse.decodeValidation[Person](json)
于 2015-09-29T05:45:00.503 回答